Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[SR-2221] Compiler should be able to prove coverage for element-wise tuple match in switch #44828

Closed
ddunbar opened this issue Jul 30, 2016 · 0 comments
Assignees
Labels
bug A deviation from expected or documented behavior. Also: expected but undesirable behavior. compiler The Swift compiler in itself

Comments

@ddunbar
Copy link
Member

ddunbar commented Jul 30, 2016

Previous ID SR-2221
Radar None
Original Reporter @ddunbar
Type Bug
Status Closed
Resolution Duplicate
Additional Detail from JIRA
Votes 0
Component/s Compiler
Labels Bug
Assignee @ddunbar
Priority Medium

md5: ed160417da86fa3734008cac95574ea3

duplicates:

  • SR-483 Exhaustivity checking for switch statement with wildcards doesn't work properly

Issue Description:

I think it would be reasonable for Swift to be able to prove the exhaustiveness of this switch statement:

$ cat z.swift
enum E {
    case empty
    case nonEmpty

    public func intersection(_ rhs: E) -> E {
        switch (self, rhs) {
        case (.empty, _):
            return .empty
        case (_, .empty):
            return .empty
        case (.nonEmpty, .nonEmpty):
            return .empty
        }
    }
}

$ swift-dev --driver-mode=swiftc -c z.swift
z.swift:13:9: error: switch must be exhaustive, consider adding a default clause
        }
        ^
@swift-ci swift-ci transferred this issue from apple/swift-issues Apr 25, 2022
This issue was closed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug A deviation from expected or documented behavior. Also: expected but undesirable behavior. compiler The Swift compiler in itself
Projects
None yet
Development

No branches or pull requests

1 participant