On 1 Mar 2014, at 19:11, Trygve Inda <cocoa...@xericdesign.com> wrote:
>> On Mar 1, 2014, at 07:23 , Trygve Inda <cocoa...@xericdesign.com> wrote: >> >>> The problem is that when there is a very small change (just adding or >>> removing one of the files in the package), the system does not save in >>> place. >>> >>> Rather it reads the previous package file completely, writes out a copy of >>> the package (400 MB) and then renames it. >>> >>> How can I get it to save in place? >> >> AFAIK, NSDocument never saves in place, and isn’t intended to (for safety >> reasons — what happens if your app crashes after some of the files have been >> updated but not others?). >> >> Instead, it achieves its package performance optimization by hard-linking >> unchanged files in the new (saved) package to files in the old (original) >> package. If your save is taking 40 seconds, that could mean: >> >> — The document is on a file system that doesn’t support hard linking. >> >> — The document is on a file system where hard linking 7500 files takes 40 >> seconds. >> >> — You didn’t preserve the original file sub-wrappers from the directory >> wrapper created when the document was opened, so NSDocument thinks all the >> files have changed. Note that it’s undocumented (again, AFAIK) what criteria >> NSDocument uses** to decide when a particular file wrapper represents “no >> change”, so it’s safest to keep the original NSFileWrapper objects from open >> time until save time. >> >> >> >> ** The most likely possibilities are ‘==’ on file wrappers, ‘isEqual:’ on >> file >> wrappers, or comparison of mod date and/or size of the actual files, but it >> could be something more obscure. >> > > > When a file is opened, my NSDocument subclass uses > > -(BOOL)readFromFileWrapper:(NSFileWrapper *)fileWrapper ofType:(NSString > *)typeName error:(NSError **)outError > > After loading it, I call > > [self setDocumentFileWrapper:fileWrapper]; > > Which stores the fileWrapper in my Document object for later use. > > > Later, when saving I use > > -(NSFileWrapper *)fileWrapperOfType:(NSString *)typeName error:(NSError > **)outError > > Even if I only call > > return documentFileWrapper; > > So the document is saved with zero changes, it takes 40 seconds on my > package with 7500 sub-items. It should happen almost instantly, but it > doesn't. > > I am using a normal Mac HFS system. > > I really need this to be faster. It is -[NSFileWrapper writeToURL:options:originalContentsURL:error:] which has the feature of writing out hard links for efficiency. But it only does it if requested, by passing a suitable URL as the original contents URL. It is my suspicion that NSDocument does not do this for you. You could set a breakpoint to test this. If so, it becomes your responsibility to override -writeToURL:… in your document subclass and write the file wrapper yourself. _______________________________________________ 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