On Fri, 31 Jul 2015 12:15:10 +0200, Jean-Daniel Dupas said:

>
>> Le 30 juil. 2015 à 18:26, Fritz Anderson <fri...@manoverboard.org> a écrit :
>> 
>> On 30 Jul 2015, at 11:03 AM, Trygve Inda <cocoa...@xericdesign.com> wrote:
>> 
>>> It seems Apple is using retain rather than copy for NSString properties in
>>> an NSManagedObject subclass.
>>> 
>>> I was always under the impression that copy should be used for NSString, so
>>> why the retain??
>> 
>> For an immutable string, -copy is implemented as a -retain. -copy is a
>guard against the receiver’s relying on the unchanging contents of a
>string whose contents can be changed. If the contents cannot in fact be
>changed, there’s no point in allocating new memory and copying the bytes
>into it.
>> 
>> It’s an implementation detail; what makes you believe it makes a difference?
>
>If it is in the property declaration, it is not an implementation
>detail, it is part of the public API.
>
>And as the receiver can’t guarantee that a passed NSString is not a
>NSMutableString under the hood, it should always declare property as
>copy, so the fact that some sample code (I guess this is what the op is
>talking about) use retain is dubious.

This has long been a weakness in the Core Data ecosystem.  Even mogenerator 
does not have an option to make things 'copy':
<https://github.com/rentzsch/mogenerator/issues/41>

I might take a stab at that next week...

Cheers,

-- 
____________________________________________________________
Sean McBride, B. Eng                 s...@rogue-research.com
Rogue Research                        www.rogue-research.com 
Mac Software Developer              Montréal, Québec, Canada

_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
https://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to