diff options
author | Stefan Monnier <monnier@iro.umontreal.ca> | 2022-09-03 11:03:01 -0400 |
---|---|---|
committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2022-09-03 15:14:58 -0400 |
commit | aad38d6010d9eef07685fa52ce93bcf70512f88b (patch) | |
tree | 321a2adea0eb71b3f1cd30c2829460d475704bc9 /lisp/emacs-lisp | |
parent | f9f92772dcdab739db54cf03dad9037f4b53473d (diff) | |
download | emacs-aad38d6010d9eef07685fa52ce93bcf70512f88b.tar.gz emacs-aad38d6010d9eef07685fa52ce93bcf70512f88b.tar.bz2 emacs-aad38d6010d9eef07685fa52ce93bcf70512f88b.zip |
* lisp/emacs-lisp/comp.el (comp-run-async-workers): Fail more gracefully
Otherwise Emacs may fail to start if it can't find a writable
`~/.emacs.d/eln-cache` directory.
Fixes bug#57562. See also Debian's bug #1017739.
Diffstat (limited to 'lisp/emacs-lisp')
-rw-r--r-- | lisp/emacs-lisp/comp.el | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/lisp/emacs-lisp/comp.el b/lisp/emacs-lisp/comp.el index 374b39e9990..a5ab12ae388 100644 --- a/lisp/emacs-lisp/comp.el +++ b/lisp/emacs-lisp/comp.el @@ -3927,8 +3927,11 @@ display a message." when (or native-comp-always-compile load ; Always compile when the compilation is ; commanded for late load. - (file-newer-than-file-p - source-file (comp-el-to-eln-filename source-file))) + ;; Skip compilation if `comp-el-to-eln-filename' fails + ;; to find a writable directory. + (with-demoted-errors "Async compilation :%S" + (file-newer-than-file-p + source-file (comp-el-to-eln-filename source-file)))) do (let* ((expr `((require 'comp) ,(when (boundp 'backtrace-line-length) `(setf backtrace-line-length ,backtrace-line-length)) |