[swift-dev] swift_retainCount in CoreFoundation
Joe Groff
jgroff at apple.com
Sat Dec 26 17:06:02 CST 2015
> On Dec 26, 2015, at 12:52 PM, Philippe Hausler <phausler at apple.com> wrote:
>
>
>> On Dec 26, 2015, at 12:31 PM, Joe Groff <jgroff at apple.com <mailto:jgroff at apple.com>> wrote:
>>
>>>
>>> On Dec 25, 2015, at 9:02 PM, Philippe Hausler <phausler at apple.com <mailto:phausler at apple.com>> wrote:
>>>
>>> > On Dec 22, 2015, at 1:08 PM, Joe Groff via swift-dev <swift-dev at swift.org <https://lists.swift.org/mailman/listinfo/swift-dev>> wrote:
>>> >
>>> > It looks like the corelibs implementation of CoreFoundation references swift_retainCount in order to implement CFGetRetainCount. Is getting the retain count necessary to CF functionality, or can these functions be removed?
>>>
>>> For some reason I was not on this list;
>>> So in response to your query about CF’s usage of CFGetRetainCount - I think we can safely forbid that function in the swift version since there is no safe way to use it (even CFMachPort is a bit dodgy for it’s usage).
>>>
>>> It might take some surgery but I can probably excise that fairly simply.
>>
>> That'd be awesome. Thanks Philippe! For CFMachPort's usage, since it's checking for a retainCount of 1, maybe we could use swift_isUniquelyReferenced* instead, which we do need to reliably support for COW.
>>
>> -Joe
>
> Actually the method that was being used there is not even compiled on mac targets, I was able to safely excise the usage and disallow the function in the Swift version of CF.
>
> I pushed this:
> https://github.com/apple/swift-corelibs-foundation/commit/d430c06fe417e285c5b120ccbf1d1082807e3b5c <https://github.com/apple/swift-corelibs-foundation/commit/d430c06fe417e285c5b120ccbf1d1082807e3b5c>
>
> Which should no longer swift_retainCount in swift-corelibs-foundation builds anymore.
Nice, thanks again Philippe!
-Joe
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-dev/attachments/20151226/1fbf3138/attachment.html>
More information about the swift-dev
mailing list