[swift-evolution] Changing __LINE__ to #line (was Re: [Review] SE-0022: Referencing the Objective-C selector of a method)
Chris Lattner
clattner at apple.com
Fri Jan 22 18:31:22 CST 2016
> On Jan 22, 2016, at 4:21 PM, David Sweeris via swift-evolution <swift-evolution at swift.org> wrote:
>
> It's only a "compiler-known type" if it's defined that way. What's wrong with just a regular tuple?
> #location = (path: __FILE__, line: __LINE__, column: __COLUMN__, function: __FUNCTION__)
This would make sense to me. One complexity here is that you’d want to use:
func f(a : Int = #location.line) {}
and our default argument model doesn’t support that. A default argument is either an expression, or one of these magic __LINE__ indicators. They aren’t really first-class values.
-Chris
>
> - Dave Sweeris
>
>> On Jan 22, 2016, at 11:42, Jordan Rose via swift-evolution <swift-evolution at swift.org> wrote:
>>
>>
>>> On Jan 21, 2016, at 21:44, Joe Groff via swift-evolution <swift-evolution at swift.org> wrote:
>>>
>>>
>>>> On Jan 21, 2016, at 9:25 PM, Erica Sadun via swift-evolution <swift-evolution at swift.org> wrote:
>>>>
>>>> Okay, you know this was coming: let's Groff this thing.
>>>>
>>>> How about #(line) where you can decouple the specific compiler implementation bits from the keyword bits without hardcoding support, enabling implementation of, for example, #(runcible) for future Swift compiler substitution logic.
>>>
>>> If you're going to bring me into it…I would prefer coalescing all these __FILE__, __LINE__, etc. things into one #sourceLocation structure. If you want one source-location-related thing, you tend to want the others, and you also want to be able to forward the source location info easily through the depths of your assertion/logging framework.
>>
>> The downside is that this becomes Yet Another Compiler-Known Type and Yet Another Thing In the Standard Library. All the current fields are string literals and integer literals.
>>
>> Jordan
>> _______________________________________________
>> 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