> On Mar 29, 2017, at 6:45 PM, Jonathan Hull via swift-evolution 
> <swift-evolution@swift.org> wrote:
> 
>> 
>> On Mar 29, 2017, at 6:32 PM, Brent Royal-Gordon <br...@architechies.com> 
>> wrote:
>> 
>>> On Mar 29, 2017, at 6:21 PM, Jonathan Hull via swift-evolution 
>>> <swift-evolution@swift.org> wrote:
>>> 
>>>> I would love it if we found a way to retain something as concise as that 
>>>> shorthand.  I'm working on a library where users will specify a collection 
>>>> of key paths pairs.  This shorthand would be a very nice piece of sugar 
>>>> making the code expressing these collections (usually literals) quite a 
>>>> bit more readable.
>>> 
>>> +1 for this.  I think it will be somewhat common to pass around arrays of 
>>> these things, and a shorthand syntax of some sort would make that nicer.  
>>> That said, I don’t want to slow down the proposal, since I will be using 
>>> this feature the very second it becomes available.
>> 
>> Agreed.
>> 
>> One more thought on this: I don't think anyone really likes the 
>> #keyPath(Type, .key1.key2)` syntax; it's just the best we've come up with. 
>> If the syntax were instead this:
>> 
>>      #keyPath(Type).key1.key2
>> 
>> I think that would look cleaner and avoid drawing distinctions based on 
>> subtle punctuation differences. I don't think it would clash with old-style 
>> key paths since you can't have a key path to a type name anyway. And support 
>> for the leading-dot syntax would fall out of it quite naturally.
> 
> I could get behind that (although it would stop us from extending KeyPaths).  
> One question in both cases: How do we represent keyPaths for static 
> properties?

Static properties are members of T.Type, so you would specify T.Type as the 
root.

-Joe
_______________________________________________
swift-evolution mailing list
swift-evolution@swift.org
https://lists.swift.org/mailman/listinfo/swift-evolution

Reply via email to