> On 27. Sep 2017, at 12:32, Karl Wagner via swift-evolution 
> <swift-evolut...@swift.org> wrote:
> 
> 
> 
>> On 25. Sep 2017, at 18:54, Rick Ballard via swift-evolution 
>> <swift-evolut...@swift.org> wrote:
>> 
>> Hi Karl and Keith,
>> 
>> (+ swift-build-dev and swift-corelibs-dev)
>> 
>> The SwiftPM core team has had some preliminary discussions already with the 
>> swift-corelibs team about the best way to support resources; whatever we do 
>> here will likely be a collaboration between SwiftPM and Foundation. We're 
>> currently defining our roadmap for SwiftPM in Swift 5, and it's not clear 
>> yet whether resource support will fit into this year or not, but either way 
>> it's clearly something we'll want to do. We're looking to encourage a 
>> thriving developer community around the Swift package manager, and we know 
>> that this will be important for many uses. If there are other limitations 
>> that are currently holding people back, we'd welcome feedback (and 
>> contributions!).
>> 
>> While we're not actively working on a proposal for resource support at the 
>> moment, if you have particular thoughts, please feel free to share them, 
>> possibly cross-posted between swift-build-dev, swift-corelibs-dev, and 
>> swift-evolution.
>> 
>> Cheers,
>> 
>>      - Rick
>> 
> 
> Thanks Rick, that’s very interesting.
> 
> I have been bouncing some ideas around my head about how to incorporate 
> external resource files as first-class “source” elements of a Swift 
> application (similar to the “resource literals” and “image literals” that we 
> have for Xcode integration).
> 
> Android has the “R” system, which generates resource-ids for things like 
> image and layout-xml resources. I don’t know if that’s a common system used 
> by a lot of platforms, but I first encountered it with Android and it has 
> some features I really like (like compile-time checking that resources 
> exist). I’ve recently been using the “R.Swift” library [1] after a 
> colleague's recommendation, which generates a similar-style interface for 
> Swift projects, and I think that’s also pretty nifty. It improves on the 
> Android system by properly-typing things like image and layout resources 
> (Android reduces them all to integer IDs). I could imagine something like 
> that either built-in to Swift itself, or as a component of SwiftPM.
> 
> We would also need some substantial runtime support. Apple’s platforms 
> introduce resource variations for different devices, localisations, screen 
> densities, colour profiles, etc - and that’s why they have their own “asset 
> catalog” format; to manage all of that complexity. A good cross-platform 
> resources abstraction would need to match that and include some way for each 
> platform to resolve its ideal variation of the resource.
> 
> There are times when rich assets belong below the UI layer. For example, I’m 
> creating a cross-platform SDK for a large company with multiple subsidiary 
> brands. The branding assets are specific in contracts between us and 
> third-parties, and we want our cross-platform SDK to be able to vend the 
> appropriate image resources. So the model object for Brand X could have an 
> ‘icon’ property and the existence of the icon would be verified when we 
> compile the SDK. That SDK could then be used on an iOS device, where the icon 
> is bound to a UIImageView, or on a server, which might render the icon as 
> part of a web-page, or on a cheap linux-based kiosk with a GTK+ UI. That’s my 
> dream.

Just to clarify: I mean that the SDK vends multiple “Brand” objects, each of 
which *must* be displayed with a particular icon. So we can’t just build a 
different SDK for each brand - each build must include resources for all brands.

- Karl


_______________________________________________
swift-corelibs-dev mailing list
swift-corelibs-dev@swift.org
https://lists.swift.org/mailman/listinfo/swift-corelibs-dev

Reply via email to