[swift-users] Annotating C APIs without changing the original header files

Douglas Gregor dgregor at apple.com
Thu May 4 18:59:49 CDT 2017


> On May 4, 2017, at 4:57 PM, Geordie Jay <geojay at gmail.com> wrote:
> 
> Great, thanks for reminding me of this feature. I couldn't see how it could be used outside of the stdlib though, is it possible to use apinotes when simply linking a C module via its modulemap ?

You can put

	<modulename>.apinotes

into the same directory as the module map.

	- Doug

> Douglas Gregor <dgregor at apple.com <mailto:dgregor at apple.com>> schrieb am Fr. 5. Mai 2017 um 01:55:
> 
>> On May 3, 2017, at 4:10 PM, Geordie J via swift-users <swift-users at swift.org <mailto:swift-users at swift.org>> wrote:
>> 
>> Hi everyone,
>> 
>> I’m about to start on another big project with Swift on Android and would like to annotate that JNI headers as much as possible before I do: specifically I’d like to make _Nonnull and CF_SWIFT_NAME annotations to the headers found in a user's jni.h.
>> 
>> The question is: is it possible to annotate headers this without changing the original header files? Specifically I’m looking for an options that allows annotations in a separate file, probably one that is read when loading the package’s module.modulemap.
>> 
>> I’d like to distribute the annotations in a SwiftPM package that also exposes the original (hopefully annotated) headers. Up until now I’ve been using Swift to override methods in code, but this isn’t as clean or extensible and I fear it may have other (particularly performance) implications.
>> 
>> I guess the alternative would be to just maintain and distribute a modified version of jni.h with the annotations, but that would be a "last resort” option.
> 
> 
> This is the role of API notes, which you can see here:
> 
> 	https://github.com/apple/swift/tree/master/apinotes <https://github.com/apple/swift/tree/master/apinotes>
> 
> with some rough documentation-in-source here:
> 
> 	https://github.com/apple/swift-clang/blob/stable/lib/APINotes/APINotesYAMLCompiler.cpp <https://github.com/apple/swift-clang/blob/stable/lib/APINotes/APINotesYAMLCompiler.cpp>
> 
> 	- Doug
> 

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-users/attachments/20170504/37d54872/attachment.html>


More information about the swift-users mailing list