Instance Property


The URL for the document’s backup file that was created during an autosave operation.


var backupFileURL: URL? { get }


This property specifies the location of the backup file, if any. If a backup file cannot be created or is not needed, the value of this property is nil.

Starting in OS X v10.8, document versions can be preserved using a backup file created during an autosave operation, which supports document versioning. This property gives you access to the backup file’s URL.

Using an autosave backup file for preserving versions is efficient. This is because an NSDocument instance is able to use the byMoving option when it calls the replaceItem(at:options:) method. The document gets the value of this property twice during saving:

  1. Before calling the writeSafely(to:ofType:for:) method: This is to check whether using the replace-by-moving option is possible and, if not, to allow the system to preserve data by instead using copying.

  2. Within the writeSafely(to:ofType:for:) method: This is to discover where to put the backup file.

When you implement the writeSafely(to:ofType:for:) method with the NSDocument.SaveOperationType.saveOperation or NSDocument.SaveOperationType.autosaveInPlaceOperation operation type, you must check this property’s value. If it is not nil, move the previous contents of the file (that would be overwritten) to the URL’s location. The default implementation of writeSafely(to:ofType:for:) does this.

To create a backup file from within your custom implementation of the writeSafely(to:ofType:for:) method, call the FileManager method replaceItem(at:withItemAt:backupItemName:options:resultingItemURL:), using a backup item name of [[self backupFileURL] lastPathComponent] and an option of withoutDeletingBackupItem option. If your custom implementation is unable to keep the backup file, you must override this property and return nil to ensure that the document’s file gets correctly preserved before it gets overwritten.

The default implementation of the writeSafely(to:ofType:for:) method returns a non-nil value based on the value of [self fileURL], but only if the document’s file needs to be preserved prior to saving or if the preservesVersions method returns false. Otherwise, it returns nil.

See Also

Reading From and Writing to Files

func read(from: FileWrapper, ofType: String)

Sets the contents of this document by reading from a file wrapper of a specified type.

var fileModificationDate: Date?

The last known modification date of the document’s on-disk representation.

func runModalSavePanel(for: NSDocument.SaveOperationType, delegate: Any?, didSave: Selector?, contextInfo: UnsafeMutableRawPointer?)

Presents a modal Save panel to the user, then tries to save the document if the user approves the panel.

var shouldRunSavePanelWithAccessoryView: Bool

A Boolean value indicating whether the document’s Save panel displays a list of supported writable document types.

var keepBackupFile: Bool

A Boolean value indicating whether the document keeps the backup files created before the document data is written to a file.

var fileURL: URL?

The location of the document’s on-disk representation.

var isDraft: Bool

A Boolean value indicating whether the document is a draft that the user has not expressed an interest in keeping around.