]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix spurious errors on Windows when deleting temporary *.eln files
authorEli Zaretskii <eliz@gnu.org>
Sun, 29 Jan 2023 07:44:53 +0000 (09:44 +0200)
committerEli Zaretskii <eliz@gnu.org>
Sun, 29 Jan 2023 07:44:53 +0000 (09:44 +0200)
* lisp/emacs-lisp/comp.el (comp--native-compile): On MS-Windows,
ignore errors when deleting a temporary .eln file.  (Bug#60996)

lisp/emacs-lisp/comp.el

index 49e3cdb8de75f55b667e9b6d15d3a835437f17b8..7ba8e956fb2bdf0246eff15700424ba82bd9e2a8 100644 (file)
@@ -4112,13 +4112,16 @@ the deferred compilation mechanism."
                 (native-elisp-load data)))
           ;; We may have created a temporary file when we're being
           ;; called with something other than a file as the argument.
-          ;; Delete it.
+          ;; Delete it if we can.
           (when (and (not (stringp function-or-file))
                      (not output)
                      comp-ctxt
                      (comp-ctxt-output comp-ctxt)
                      (file-exists-p (comp-ctxt-output comp-ctxt)))
-            (delete-file (comp-ctxt-output comp-ctxt))))))))
+            (cond ((eq 'windows-nt system-type)
+                   ;; We may still be using the temporary .eln file.
+                   (ignore-errors (delete-file (comp-ctxt-output comp-ctxt))))
+                  (t (delete-file (comp-ctxt-output comp-ctxt))))))))))
 
 (defun native-compile-async-skip-p (file load selector)
   "Return non-nil if FILE's compilation should be skipped.