18.3.2.3 Copying vs. Renaming
Backup files can be made by copying the old file or by renaming it. This makes a difference when the old file has multiple names (hard links). If the old file is renamed into the backup file, then the alternate names become names for the backup file. If the old file is copied instead, then the alternate names remain names for the file that you are editing, and the contents accessed by those names will be the new contents.
The method of making a backup file may also affect the file’s owner and group. If copying is used, these do not change. If renaming is used, you become the file’s owner, and the file’s group becomes the default (different operating systems have different defaults for the group).
The choice of renaming or copying is made as follows:
-
If the variable
backup-by-copying
is non-nil
(the default isnil
), use copying. -
Otherwise, if the variable
backup-by-copying-when-linked
is non-nil
(the default isnil
), and the file has multiple names, use copying. -
Otherwise, if the variable
backup-by-copying-when-mismatch
is non-nil
(the default ist
), and renaming would change the file’s owner or group, use copying.
If you change backup-by-copying-when-mismatch
to nil
,
Emacs checks the numeric user-id of the file’s owner and the numeric
group-id of the file’s group. If either is
no greater than backup-by-copying-when-privileged-mismatch
, then it
behaves as though backup-by-copying-when-mismatch
is
non- nil
anyway.
- Otherwise, renaming is the default choice.
When a file is managed with a version control system (see Version Control), Emacs does not normally make backups in the usual way for that file. But committing (a.k.a. checking in, see Concepts of Version Control) new versions of files is similar in some ways to making backups. One unfortunate similarity is that these operations typically break hard links, disconnecting the file name you visited from any alternate names for the same file. This has nothing to do with Emacs—the version control system does it.