In Windows and OS/2, when a file is created or modified, the archive bit is set (i.e. turned on), and when the file has been backed up, the archive bit is cleared (i.e. turned off). Thus, the meaning of the archive bit is "this file has not been archived". In CP/M, the meaning is inverted: creating or modifying a file clears the archive bit, and the bit is set when the file is backed up.
Backup software may provide the option to do a full backup while clearing archive bits – that is, to back up all files regardless of their archive bit status, and to clear the archive bit for all files processed by the backup. This allows for the creation of an initial full backup that will be supplemented by incremental backups in the future. Later, the incremental backup task uses the archive bit to distinguish which files have already been backed up, and selects only the new or modified files for backup.
The operating system never clears the archive bit unless explicitly told to do so by the user. Even when a user explicitly tells the operating system to copy a file for the purpose of archiving it, the archive bit will still not be cleared. A specific command for clearing or setting the bit must be executed. On the other hand, whenever a file with a clear archive bit is modified (edited), or copied or moved to a new location, the operating system will set the archive bit on the target file. Typically on a file system that has never been formally backed up, nearly all of the files will have their archive bits set, as there are few applications that make use of archive bits without the user's request.
In MS-DOS as well as nearly all versions of Windows, status of the archive bit can be viewed or changed with the attrib command-line utility, or by viewing the properties of a file with the Windows shell or Windows Explorer. The archive bit's status can also be viewed or changed with the GetFileAttributes, GetFileAttributesEx, and SetFileAttributes Windows APIs. The archive bit can be set or cleared with the attributes property in VBScript or JScript.
The archive bit is a file attribute and not part of the file itself, so the contents of the file remain unchanged when the status of the archive bit changes.
Relying on the archive bit for backing up files can be unreliable if multiple backup programs are setting and clearing the archive bit on the same volume. Another possibility is to use the timestamp of the last change to the file or directory. This is typically the technique used in UNIX-like operating systems.
- "GetFileAttributes function (Windows)" (in en). http://msdn.microsoft.com/en-us/library/aa364944(v=VS.85).aspx.
- "GetFileAttributesEx function (Windows)" (in en). http://msdn.microsoft.com/en-us/library/aa364946(v=VS.85).aspx.
- "SetFileAttributes function (Windows)" (in en). https://msdn.microsoft.com/en-us/library/aa365535(v=VS.85).aspx.
- "Attributes Property" (in en). https://msdn.microsoft.com/en-us/library/5tx15443(v=vs.84).aspx.
- "The Windows archive bit is evil and must be stopped". 28 March 2005. https://www.computerworld.com/article/2598081/the-windows-archive-bit-is-evil-and-must-be-stopped.html.
Original source: https://en.wikipedia.org/wiki/Archive bit. Read more