# HG changeset patch # User Martin Rudalics # Date 1188461737 0 # Node ID 7d09f83a108537ee622f64b6f6b7d71ad2523bd3 # Parent 725c01b32a716e572f9809081e0d77b6a8f03046 (backup-buffer-copy): Try to overwrite old backup first. diff -r 725c01b32a71 -r 7d09f83a1085 lisp/files.el --- a/lisp/files.el Thu Aug 30 08:06:06 2007 +0000 +++ b/lisp/files.el Thu Aug 30 08:15:37 2007 +0000 @@ -3127,18 +3127,22 @@ ;; loosen them later, whereas it's impossible to close the ;; time-window of loose permissions otherwise. (set-default-file-modes ?\700) - (while (condition-case () - (progn - (and (file-exists-p to-name) - (delete-file to-name)) - (copy-file from-name to-name nil t) - nil) - (file-already-exists t)) - ;; The file was somehow created by someone else between - ;; `delete-file' and `copy-file', so let's try again. - ;; rms says "I think there is also a possible race - ;; condition for making backup files" (emacs-devel 20070821). - nil)) + (when (condition-case nil + ;; Try to overwrite old backup first. + (copy-file from-name to-name t t) + (error t)) + (while (condition-case nil + (progn + (when (file-exists-p to-name) + (delete-file to-name)) + (copy-file from-name to-name nil t) + nil) + (file-already-exists t)) + ;; The file was somehow created by someone else between + ;; `delete-file' and `copy-file', so let's try again. + ;; rms says "I think there is also a possible race + ;; condition for making backup files" (emacs-devel 20070821). + nil))) ;; Reset the umask. (set-default-file-modes umask))) (and modes