Pre-expand lexical-let, since otherwise it requires cl to be loaded
Fixes https://github.com/jwiegley/use-package/issues/571
This commit is contained in:
@@ -671,14 +671,17 @@ If ALLOW-EMPTY is non-nil, it's OK for ARGS to be an empty list."
|
||||
(defun use-package-memoize (f arg)
|
||||
"Ensure the macro-expansion of F applied to ARG evaluates ARG
|
||||
no more than once."
|
||||
(let ((loaded (cl-gensym "use-package--loaded"))
|
||||
(result (cl-gensym "use-package--result"))
|
||||
(next (cl-gensym "use-package--next")))
|
||||
`((lexical-let (,loaded ,result)
|
||||
,@(funcall f `((if ,loaded
|
||||
,result
|
||||
(setq ,loaded t)
|
||||
(setq ,result ,arg))))))))
|
||||
(let* ((loaded (cl-gensym "use-package--loaded"))
|
||||
(result (cl-gensym "use-package--result"))
|
||||
(next (cl-gensym "use-package--next"))
|
||||
(body `(lexical-let (,loaded ,result)
|
||||
,@(funcall f `((if ,loaded
|
||||
,result
|
||||
(setq ,loaded t)
|
||||
(setq ,result ,arg)))))))
|
||||
`(,(if (eq use-package-verbose 'errors)
|
||||
body
|
||||
(macroexpand body)))))
|
||||
|
||||
(defsubst use-package-normalize-value (label arg)
|
||||
"Normalize the Lisp value given by ARG.
|
||||
|
||||
@@ -1213,8 +1213,7 @@
|
||||
(eval-after-load 'quux
|
||||
'(if ,_ ,_
|
||||
(setq ,_ t)
|
||||
(setq ,_ (require 'foo nil nil)))))))
|
||||
))
|
||||
(setq ,_ (require 'foo nil nil)))))))))
|
||||
|
||||
(ert-deftest use-package-test/:after-7 ()
|
||||
(match-expansion
|
||||
@@ -1228,8 +1227,7 @@
|
||||
(eval-after-load 'bow
|
||||
'(if ,_ ,_
|
||||
(setq ,_ t)
|
||||
(setq ,_ (require 'foo nil nil)))))
|
||||
))
|
||||
(setq ,_ (require 'foo nil nil)))))))
|
||||
|
||||
(ert-deftest use-package-test/:after-8 ()
|
||||
(match-expansion
|
||||
@@ -1254,8 +1252,7 @@
|
||||
(eval-after-load 'quux
|
||||
'(if ,_ ,_
|
||||
(setq ,_ t)
|
||||
(setq ,_ (require 'foo nil nil)))))))
|
||||
))
|
||||
(setq ,_ (require 'foo nil nil)))))))))
|
||||
|
||||
(ert-deftest use-package-test/:after-9 ()
|
||||
(match-expansion
|
||||
@@ -1270,8 +1267,7 @@
|
||||
'(eval-after-load 'bow
|
||||
'(if ,_ ,_
|
||||
(setq ,_ t)
|
||||
(setq ,_ (require 'foo nil nil))))))
|
||||
))
|
||||
(setq ,_ (require 'foo nil nil))))))))
|
||||
|
||||
(ert-deftest use-package-test/:after-10 ()
|
||||
(match-expansion
|
||||
@@ -1289,8 +1285,7 @@
|
||||
(eval-after-load 'baz
|
||||
'(if ,_ ,_
|
||||
(setq ,_ t)
|
||||
(setq ,_ (require 'foo nil nil)))))
|
||||
))
|
||||
(setq ,_ (require 'foo nil nil)))))))
|
||||
|
||||
(ert-deftest use-package-test/:demand-1 ()
|
||||
(match-expansion
|
||||
|
||||
Reference in New Issue
Block a user