[swift-evolution] [Proposal] [Stage–2] `return` consistency for single-expressions

Matthew Johnson matthew at anandabits.com
Fri Feb 17 08:46:25 CST 2017


> On Feb 17, 2017, at 8:41 AM, Vladimir.S via swift-evolution <swift-evolution at swift.org> wrote:
> 
> I think I like this, but what about guard?
> 
> func f(x: Int) -> Int {
> 	guard x > 0 else { return 0 }
> ...
> }
> 
> vs
> 
> func f(x: Int) -> Int {
> 	guard x > 0 else { 0 }
>> }

Any time you have a guard statement you no longer have a single expression.  There is at least one expression in the guard clause itself, at least one in the else block, and at least one following the guard statement.

> 
> ?
> 
> On 17.02.2017 11:20, Adrian Zubarev via swift-evolution wrote:
>> I’d like to revive an additive proposal that couldn’t make it into Swift 3.
>> This proposal has a small improvement to the language compared to other big
>> features currently being proposed. It almost feels like a bug fix rather
>> than a new feature, but it still needs a full and quick review process.
>> 
>> You can read the formatted version here:
>> https://github.com/apple/swift-evolution/pull/608
>> 
>> 
>>  |return| consistency for single-expressions
>> 
>>  * Proposal: SE-NNNN
>>    <https://github.com/apple/swift-evolution/blob/master/proposals/nnnn-single-expression-optional-return.md>
>>  * Author: Adrian Zubarev <https://github.com/DevAndArtist>
>>  * Status: *Awaiting review*
>>  * Review manager: TBD
>> 
>> 
>>    Introduction
>> 
>> Any single-expression closure can omit the |return| statement. This
>> proposal aims to make this feature more consistent in some other corners of
>> the language.
>> 
>> Original swift-evolution thread: * [Pitch] [Stage–2] |return| consistency
>> for single-expressions * [Pitch] (Bofore Swift 3) Make |return| optional in
>> computed properties for a single case
>> <https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20160523/019260.html>
>> 
>> 
>>    Motivation
>> 
>> Closures can omit the |return| and have an inferred return type:
>> 
>> |let _ = { 42 } // Type: () -> Int let _ = [1,2,3].map { $0 * 5 } // T == Int |
>> 
>> There are also value returning code blocks in the language that feel the
>> same but are inconsistent to the mentioned feature:
>> 
>> |// Read-write computed property: var integer: Int { get { return 2016 } set
>> { /* do some work */ } } // Read-only computed property: var string: String
>> { return "hello swift" } // Function: func pi() -> Double { return 3.141 }
>> // Read-Write subscript: subscript(index: Int) -> Int { get { return index
>> % 2 } set { /* do some work */ } } // Read-only subscript: subscript(index:
>> Int) -> Int { return index * 2 } |
>> 
>> 
>>    Proposed solution
>> 
>> Make |return| optional for the following top level code blocks that only
>> contain a single expression:
>> 
>>  * /variable-declaration/
>>  * /getter-setter-block/
>>  * /getter-clause/
>>  * /function-body/
>>  * /subscript-declaration/
>> 
>> That will allow us to rewrite the above example to:
>> 
>> |// Read-Write computed property: var integer: Int { get { 2016 } ... } //
>> Read-only computed property: var string: String { "hello swift" } //
>> Function: func pi() -> Double { 3.141 } // Read-Write subscript:
>> subscript(index: Int) -> Int { get { index % 2 } ... } // Read-only
>> subscript: subscript(index: Int) -> Int { index * 2 } |
>> 
>> *Possible real world example:*
>> 
>> |// Today public struct Character { public let source: Module.Source private
>> let _pointer: UnsafePointer<Swift.Character> public var value:
>> Swift.Character { return self._pointer.pointee } ... } // Rewritten: public
>> struct Character { ... public var value: Swift.Character {
>> self._pointer.pointee } ... } |
>> 
>> 
>>    Impact on existing code
>> 
>> None, this change will only relax some existing rules.
>> 
>> 
>>    Alternatives considered
>> 
>> Leave this as is and live with such inconsistency.
>> 
>> 
>> 
>> --
>> Adrian Zubarev
>> Sent with Airmail
>> 
>> 
>> 
>> _______________________________________________
>> swift-evolution mailing list
>> swift-evolution at swift.org
>> https://lists.swift.org/mailman/listinfo/swift-evolution
>> 
> _______________________________________________
> 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