Also didn't know `case _: ` works as `default`. So we have 2 things that do exactly the same. Agree, that leaving `case _:` and removing 'default' will increase the consistency of the language. I even think `case _:` is better than `default` in any way. Don't agree that this case confuse anybody : each language has its own special syntax features. If one will teach Swift as first language - no problems at all, `case _: ` construction is very simple and understandable. If one will teach Swift as next language, so this person is professional enough to use `case _:` in Swift instead of `default`, don't see any tragedy here.
But yes, I see that this is "commonly rejected proposal", so OK.

On 17.06.2016 23:54, Tony Allevato via swift-evolution wrote:
Agreed, it sounds like default should be treated as a contextual keyword in
this case.

It never even occurred to me that "case _:" would work as a replacement for
default, but it does even today—and now that I've seen it, it makes total
sense. I could definitely get behind a proposal to remove "default" as a
keyword from the language entirely in favor of that. It blends well with
other pattern matching. The only concern I would have would be about
discoverability, but it would be easy to have the compiler emit an error
when it sees default in a switch: "default is unsupported; use case _ instead."


On Fri, Jun 17, 2016 at 1:45 PM E. Maloney via swift-evolution
<[email protected] <mailto:[email protected]>> wrote:

    While upgrading to Swift 3, I noticed that I had a few enums with cases
    named .Default that, after being converted to lowercase, now need to be
    rendered using the ugly .`default` notation.

    I also noticed something similar while reading the docs for
    NotificationCenter (the NSNotificationCenter replacement, that is, not
    the NotificationCenter that governs the notification center UI);
    “default” can’t be used as a function name without escaping, so the
    declaration is:

    class func `default`()

    It seems to me that in the case of function names and enum cases, the
    parser should be able to unambiguously distinguish between the Swift
    keyword “default” and a user-defined name “default”, since IIRC the
    keyword “default” can only be used in parameter lists for generated
    headers and as the last item in a switch statement.

    (Perhaps this is also another argument in favor of using “case _:” in
    place of “default:” in a switch statement.)

    What do you think? Is there any reason this *wouldn’t* be feasible?
    _______________________________________________
    swift-evolution mailing list
    [email protected] <mailto:[email protected]>
    https://lists.swift.org/mailman/listinfo/swift-evolution



_______________________________________________
swift-evolution mailing list
[email protected]
https://lists.swift.org/mailman/listinfo/swift-evolution

_______________________________________________
swift-evolution mailing list
[email protected]
https://lists.swift.org/mailman/listinfo/swift-evolution

Reply via email to