I agree with David.

I don’t think I’ve ever omitted parenthesis in the argument list of a closure; 
not only that, but I think that omitting them in that case *reduces* clarity, 
making the closure harder to parse visually.

Nicola

> What is your evaluation of the proposal?
> I reluctantly agree with the proposal with the following caveat: I do not 
> agree with the rationale to support being able to choose to omit the () for 
> the parameter list of the closure declaration.
> 
> I see no cohesive argument that says that the parens should be required in 
> some cases but not in others when talking about parameter lists.
> 
> I believe the proposal should be amended that the following should be the 
> only allowable forms:
> 
> y = x.sorted { (lhs : Int, rhs : Int) ->Bool in rhs<lhs }
> y = x.sorted { (lhs, rhs) in rhs<lhs }
> y = x.sorted { $1<$0 }
> 
> I’ve bolded the change above, today this is allowable:
> 
> y = x.sorted { lhs, rhs in rhs<lhs }
> 
> I’ve read the argument about why it’s ok to elide the parens here, I simply 
> disagree with the author’s premise that this is a structurally significant 
> different form. Not requiring the parens for this parameter list begs the 
> question why other forms require them and provides a similar ambiguity of 
> whether the closure takes two parameters or a single tuple parameter from 
> both of these valid syntaxes today:
> 
> y = x.sorted { lhs, rhs in rhs<lhs }
> y = x.sorted { (lhs, rhs) in rhs<lhs }
> 
> I don’t see how this is fundamentally different than the example in the 
> “Motivation” section:
> 
> (Int, Float) ->Int // Takes two arguments, or takes one two-argument tuple?
> 
> While I will concede that `(lhs, rhs)` is not a valid tuple declaration, I’d 
> still argue that it’s too subtle of a difference to be used a primary means 
> of justification. If we are going to remove the ambiguity, let’s remove it 
> for all parameter list scenarios.
> 
> Is the problem being addressed significant enough to warrant a change to 
> Swift?
> Potentially.
> 
> Does this proposal fit well with the feel and direction of Swift?
> Yes.
> 
> How much effort did you put into your review? A glance, a quick reading, or 
> an in-depth study?
> I participated in the original discussion thread as well as tested out many 
> different combinations function and closure syntax in the Swift Playground.
> 
> -David
> 
> 
> 
> > On Apr 25, 2016, at 9:22 PM, Douglas Gregor via 
> > swift-evolution<swift-evolution at swift.org>wrote:
> > 
> > Hello Swift community,
> > 
> > The review of SE-0066 "Standardize function type argument syntax to require 
> > parentheses" begins now and runs through May 2, 2016. The proposal is 
> > available here:
> > 
> > https://github.com/apple/swift-evolution/blob/master/proposals/0066-standardize-function-type-syntax.md<https://github.com/apple/swift-evolution/blob/master/proposals/0066-standardize-function-type-syntax.md>
> > Reviews are an important part of the Swift evolution process. All reviews 
> > should be sent to the swift-evolution mailing list at
> > 
> > https://lists.swift.org/mailman/listinfo/swift-evolution<https://lists.swift.org/mailman/listinfo/swift-evolution>
> > or, if you would like to keep your feedback private, directly to the review 
> > manager. When replying, please try to keep the proposal link at the top of 
> > the message:
> > 
> > Proposal link:
> > 
> > https://github.com/apple/swift-evolution/blob/master/proposals/0066-standardize-function-type-syntax.md<https://github.com/apple/swift-evolution/blob/master/proposals/0066-standardize-function-type-syntax.md>
> > Reply text
> > 
> > Other replies
> > <https://github.com/apple/swift-evolution#what-goes-into-a-review-1>What 
> > goes into a review?
> > 
> > The goal of the review process is to improve the proposal under review 
> > through constructive criticism and, eventually, determine the direction of 
> > Swift. When writing your review, here are some questions you might want to 
> > answer in your review:
> > 
> > What is your evaluation of the proposal?
> > Is the problem being addressed significant enough to warrant a change to 
> > Swift?
> > Does this proposal fit well with the feel and direction of Swift?
> > If you have used other languages or libraries with a similar feature, how 
> > do you feel that this proposal compares to those?
> > How much effort did you put into your review? A glance, a quick reading, or 
> > an in-depth study?
> > More information about the Swift evolution process is available at
> > 
> > https://github.com/apple/swift-evolution/blob/master/process.md<https://github.com/apple/swift-evolution/blob/master/process.md>
> > Thank you,
> > 
> > Doug Gregor
> > 
> > Review Manager
> > 
> > 
> > _______________________________________________
> > swift-evolution mailing list
> > swift-evolution at swift.org
> > 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