]> git.eshelyaron.com Git - emacs.git/commitdiff
(backup-buffer-copy): Try to overwrite old backup first.
authorMartin Rudalics <rudalics@gmx.at>
Thu, 30 Aug 2007 08:16:55 +0000 (08:16 +0000)
committerMartin Rudalics <rudalics@gmx.at>
Thu, 30 Aug 2007 08:16:55 +0000 (08:16 +0000)
lisp/ChangeLog
lisp/files.el

index a7cbdf407cb84cf30187da2fa696c516ad43383d..76a6a7c4726a87774c948cf3a40b67c4cc92ef18 100644 (file)
@@ -1,3 +1,8 @@
+2007-08-30  Martin Rudalics  <rudalics@gmx.at>
+
+       * files.el (backup-buffer-copy): Try to overwrite old backup
+       first.
+
 2007-08-29  Martin Rudalics  <rudalics@gmx.at>
 
        * repeat.el (repeat): Use last-repeatable-command instead of
index 69ebf460781878ca170276e95216b07273786b46..bc482c8f37bd6d403c3d58753d8a7216754d3a94 100644 (file)
@@ -3127,18 +3127,22 @@ BACKUPNAME is the backup file name, which is the old file renamed."
          ;; 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