[swift-evolution] [Proposal Draft] Literal Syntax Protocols

Dave Abrahams dabrahams at apple.com
Wed Jun 29 01:44:01 CDT 2016


on Tue Jun 28 2016, Erica Sadun <swift-evolution at swift.org> wrote:

>> On Jun 28, 2016, at 9:21 PM, Sean Heber <sean at fifthace.com> wrote:
>> 
>> IntegerLiteralExpressable?
>> 
>> Does Apple employ any philosophers? We might need one...
>> 
>> l8r
>> Sean
>> 
>
> Aaaaaand...welcome to last night.
>
> The problem being, that people see this and think that the type can be
> expressed as an integer literal, 

**Which is almost exactly the right interpretation, as I keep pointing
out.**  How can this be considered a valid argument against that name?

> not that an integer literal can be expressing the type.
> (I won't even bring up other associations for that word since most of
> the subscribers of this mailing list have not been nursing mothers
> although some may be familiar with the technique.)
>
> -- E
>
>> 
>>> On Jun 28, 2016, at 10:02 PM, Erica Sadun <erica at ericasadun.com> wrote:
>>> 
>>> 
>>>> On Jun 28, 2016, at 8:08 PM, Sean Heber <sean at fifthace.com> wrote:
>>>> 
>>>> What about..
>>>> 
>>>> Syntax.ConvertibleFromIntegerLiteral
>>>> etc..
>>> 
>>> I like it but Dave has already expressed that this isn't conversion. This
>>> is something distinct, magical, and more importantly, ineffable.
>>> 
>>> He says it means an instance of the type can be written as a literal, and
>>> not converted from a literal. He writes:
>>> 
>>>> Conformance to this protocol does *not* mean you can initialize the type with
>>>> a literal. 
>>>> 
>>>> Proof:
>>>> 
>>>> func f<T: IntegerLiteralConvertible>() -> T {
>>>>  return T(integerLiteral: 43) // Error
>>>>  return T(43)                 // Also an Error
>>>> }
>>>> 
>>>> It means an instance of the type can be *written* as a literal:
>>>> 
>>>> func f<T: IntegerLiteralConvertible>() -> T {
>>>>  return 43   // OK
>>>> }
>>>>> 
>>> 
>>> So we're looking at something more like:
>>> 
>>> Syntax.AnIntegerLiteralCanBeSubstitutedForThisTypeAndTheCompilerWillNotBarf
>>> 
>>> -- E
>>> 
>>> 
>
> _______________________________________________
> swift-evolution mailing list
> swift-evolution at swift.org
> https://lists.swift.org/mailman/listinfo/swift-evolution

-- 
Dave



More information about the swift-evolution mailing list