[swift-users] Possible compiler bug? Unable to extend a type whose name clashes
Evan Maloney
emaloney at gilt.com
Wed Mar 9 10:23:03 CST 2016
Thanks a lot, Jordan; your suspicion is correct! That appears to be the issue I'm having--although unlike what's captured in the JIRA ticket, in my case there are no generics involved.
Would you mind if I updated this ticket with the additional info related to the scenario I hit?
> On Mar 8, 2016, at 5:41 PM, Jordan Rose <jordan_rose at apple.com> wrote:
>
> Hi, Evan. Just a suspicion: do you also have a type named AppleTart? In that case you'd be hitting SR-898 <https://bugs.swift.org/browse/SR-898>, rather than a specific issue with extensions.
>
> Jordan
>
>
>> On Mar 8, 2016, at 14:26, Evan Maloney via swift-users <swift-users at swift.org <mailto:swift-users at swift.org>> wrote:
>>
>> I recently ran into a situation where I needed to import a symbol with the same name from two different modules, and noticed that the usual Swift technique of disambiguating using the package name doesn't work when used with extensions.
>>
>> In my case, I have a package 'LegacyStore' and a package 'AppleTart', both of which contain a type named 'User'.
>>
>> In the case of LegacyStore, User is an Objective-C class, and in the case of AppleTart, User is a Swift struct.
>>
>> Normally, I'd be able to refer to one as 'LegacyStore.User' and the other as 'AppleTart.User', but when using this notation for an extension:
>>
>> extension AppleTart.User
>> {
>> public var legacyUser: LegacyStore.User {
>> // implementation
>> }
>> }
>>
>> ...I get a compiler error on the extension declaration line:
>>
>> error: 'User' is not a member type of 'AppleTart'
>>
>> Note that the 'LegacyStore.User' notation used in the var declaration never triggers a compiler error, so I'm assuming the notation just isn't supported yet in the context of declaring an extension.
>>
>> Fortunately, there's a (somewhat cumbersome) work-around, which is to create two separate files, one for each module. Within each file import just that one module, and create a typealias for each clashing name using package-qualified name of the type.
>>
>> For example, here's the relevant part of my AppleTartTypeDisambiguation.swift file:
>>
>> import AppleTart
>>
>> public typealias AppleTartUser = User
>>
>> And here's my LegacyStoreTypeDisambiguation.swift file:
>>
>> import LegacyStore
>>
>> public typealias LegacyUser = User
>>
>> I can then use the typealiases to extend either type. For example, here's how I successfully extended AppleTart.User:
>>
>> extension AppleTartUser
>> {
>> public var legacyUser: LegacyStore.User {
>> // implementation
>> }
>> }
>>
>> Should the inability to extend a type using the qualified type name be considered a compiler bug? I'm assuming yes. If so, I'll file a ticket.
>>
>> _______________________________________________
>> swift-users mailing list
>> swift-users at swift.org <mailto:swift-users at swift.org>
>> https://lists.swift.org/mailman/listinfo/swift-users
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-users/attachments/20160309/97e2175e/attachment.html>
More information about the swift-users
mailing list