My suggestion of allowing tuples as raw values instead doesn't burden the 
language and also does not eliminate rawValue (treat previously supported raw 
value types as one value tuples), reads very cleanly and supports a syntax 
we're already familiar with. I don't see how the 'where' syntax reads like 
natural language and I agree it doesn't match other uses of where in the 
language.



-----Original Message-----
From: "Jānis Kiršteins via swift-evolution" <swift-evolution@swift.org>
Sent: ‎28/‎05/‎2016 10:54 AM
To: "Brent Royal-Gordon" <br...@architechies.com>
Cc: "swift-evolution" <swift-evolution@swift.org>
Subject: Re: [swift-evolution] [Proposal] Enums with static stored 
propertiesfor each case

> - Abusing rawValue is just that: an abuse.

My original proposal does not replace rawValue and is compatible with it.

> - Using `where` just doesn't match the use of `where` elsewhere in the 
> language; everywhere else, it's some kind of condition.

It is also used in generic type constraints. Plus it reads like human
language: `case mercury where (mass: 3.303e+23, radius: 2.4397e6)`

> - Dictionaries are the most straightforward way to handle this with the 
> current language, but their lack of exhaustiveness checking is a problem.

Dictionaries can be used as workaround, but they cannot (lack of
exhaustiveness) solve the problem.

> What I would do is borrow the "accessors" concept from the property behaviors 
> proposal and extend it so that it supported both functions and variables.

Wouldn't accessor just be a redundant keyword here? Currently enums do
not support stored properties, so I guess there is no extra need to
mark properties with any special keyword.

Property accessors might work for enums with associated values, but
not so well without them.

On Fri, May 27, 2016 at 3:43 PM, Brent Royal-Gordon via
swift-evolution <swift-evolution@swift.org> wrote:
>> The suggested solution based on 'accessor' - will create assotiated 
>> properties each time the enum instace created, for each instance of enum 
>> type.
>
> No; property accessors would be either computed or constant (so that all 
> instances of a given case can share storage). This is much the way they would 
> behave if they were included in behaviors.
>
> You could write a property accessor with a setter, but it would have to be 
> computed, and manipulate `self`'s cases and associated values:
>
>         enum Optional<T> {
>                 accessor var unwrapped: T { get set }
>
>                 case none {
>                         unwrapped {
>                                 get { fatalError("No value") }
>                                 set { self = .some(newValue) }
>                         }
>                 }
>                 case some (_ value: T) {
>                         unwrapped {
>                                 get { return value }
>                                 set { self = .some(newValue) }
>                         }
>                 }
>         }
>
> --
> Brent Royal-Gordon
> Architechies
>
> _______________________________________________
> swift-evolution mailing list
> swift-evolution@swift.org
> https://lists.swift.org/mailman/listinfo/swift-evolution
_______________________________________________
swift-evolution mailing list
swift-evolution@swift.org
https://lists.swift.org/mailman/listinfo/swift-evolution
_______________________________________________
swift-evolution mailing list
swift-evolution@swift.org
https://lists.swift.org/mailman/listinfo/swift-evolution

Reply via email to