Precisely my point, but much better put! In this specific case I think you should be OK since -setFileURL: is there for overriding, and AppKit bypassing it would rather miss that goal. Theoretically though, Apple could fairly happily turn off KVO-support, perhaps for performance reasons.
I'd advise subclassing to add your own notification posting code. On 1 Jun 2010, at 22:35, Kyle Sluder wrote: > To clarify: Mike is of course correct that any class that doesn't have > an override of +automaticallyNotifiesObserversForKey: which returns no > for a given key, and that always sets values of that key in a > KVC-compliant manner, will generate KVO notifications for that key. > And there are many Cocoa classes that have not bothered to override > +automaticallyNotifiesObservesrForKey:. But one should *not* develop > the expectation that most, or even a substantial portion, of Cocoa is > KVO-compliant, because it is not. > > --Kyle Sluder > > On Tue, Jun 1, 2010 at 2:15 PM, Mike Abdullah <cocoa...@mikeabdullah.net> > wrote: >> By default Cocoa classes use automatic KVO. So long as Cocoa always changes >> the URL by calling -setFileURL: you will get proper notifications. >> >> On 1 Jun 2010, at 22:02, Jerry Krinock wrote: >> >>> There is no mention in -[NSDocument fileURL] documentation, nor in 10.5 or >>> 10.6 release notes, that this property is observable using KVO. But when I >>> added some code to do this, created a document, and renamed the document in >>> Finder while the document was open, my observer logged a hit. >>> >>> Is there some underlying or other documentation I don't know about? >>> >>> Jerry Krinock >>> >>> >>> - (void)observeValueForKeyPath:(NSString*)keyPath >>> ofObject:(id)object >>> change:(NSDictionary*)change >>> context:(void*)context { >>> NSLog(@"2796: keyPath %@ observed:\n%@", keyPath, change) ; >>> } >>> >>> - (id)init { >>> self = [super init] ; >>> if (self != nil) { >>> [self addObserver:self >>> forKeyPath:@"fileURL" >>> options:NSKeyValueObservingOptionNew >>> context:NULL] ; >>> } >>> >>> return self ; >>> } >>> >>> - (void)dealloc { >>> [self removeObserver:self >>> forKeyPath:@"fileURL"] ; >>> >>> ...; >>> [super dealloc]; >>> } >>> >>> >>> _______________________________________________ >>> >>> 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: >>> http://lists.apple.com/mailman/options/cocoa-dev/cocoadev%40mikeabdullah.net >>> >>> This email sent to cocoa...@mikeabdullah.net >> >> _______________________________________________ >> >> 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: >> http://lists.apple.com/mailman/options/cocoa-dev/kyle.sluder%40gmail.com >> >> This email sent to kyle.slu...@gmail.com >> _______________________________________________ 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: http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com This email sent to arch...@mail-archive.com