[swift-evolution] [Review] SE 0192 - Non-Exhaustive Enums

Cheyo Jimenez cheyo at masters3d.com
Sun Dec 31 12:21:28 CST 2017



On Dec 31, 2017, at 8:59 AM, Ben Rimmington via swift-evolution <swift-evolution at swift.org> wrote:

>> On 21 Dec 2017, at 03:32, John McCall wrote:
>> 
>>>> On Dec 20, 2017, at 10:16 PM, Brent Royal-Gordon wrote:
>>>> 
>>>> On Dec 19, 2017, at 2:58 PM, Ted Kremenek wrote:
>>>> 
>>>>    • What is your evaluation of the proposal?
>>> 
>>> I am pleased with the broad strokes of this design. I have quibbles with three areas:
>>> 
>>> 1. The `@exhaustive` attribute may be confusing because the term doesn't suggest versioning. My best alternative suggestion is `@frozen`, which matches existing programming terminology: something that has been frozen will not be changed in the future.
>> 
>> I rather like @frozen.  We could use that across language features, so that we don't end up with a keyword per kind of declaration.
> 
> Could this also be used on functions to make them inlinable?
> i.e. The body of the function has been frozen.
> 
> ```
> @frozen
> public func a()
> 
> @available(*, frozen)
> public func b()
> 
> @available(swift, introduced: 4.1, frozen: 5.0)
> public func c()
> 
> ```

My understanding is that frozen / exhaustible is guaranteed by the compiler while inlineable is more of a strong suggestion to the compiler. It would be confusing to use the same word for both. 
> 
> <https://github.com/apple/swift-evolution/blob/master/proposals/0192-non-exhaustive-enums.md>
> <https://github.com/apple/swift-evolution/blob/master/proposals/0193-cross-module-inlining-and-specialization.md>
> 
> -- Ben
> 
> _______________________________________________
> swift-evolution mailing list
> swift-evolution at swift.org
> https://lists.swift.org/mailman/listinfo/swift-evolution


More information about the swift-evolution mailing list