summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp
diff options
context:
space:
mode:
authorStefan Monnier <monnier@iro.umontreal.ca>2005-12-19 02:17:38 +0000
committerStefan Monnier <monnier@iro.umontreal.ca>2005-12-19 02:17:38 +0000
commitd2474df414cd0b6dc81095a8b701e5cde628cf4b (patch)
tree3b77459a8e785891b0f7f1a33522f77b988776c4 /lisp/emacs-lisp
parent294060c67fb2955014cf6e54f52d0a2a0b43e6f0 (diff)
downloademacs-d2474df414cd0b6dc81095a8b701e5cde628cf4b.tar.gz
(cl-macroexpand-all): Fix code-walk for
lexical-let when encountering ((lambda (...) ...) ...).
Diffstat (limited to 'lisp/emacs-lisp')
-rw-r--r--lisp/emacs-lisp/cl-extra.el5
1 files changed, 5 insertions, 0 deletions
diff --git a/lisp/emacs-lisp/cl-extra.el b/lisp/emacs-lisp/cl-extra.el
index 4ac1a72b0d7..c5a006912df 100644
--- a/lisp/emacs-lisp/cl-extra.el
+++ b/lisp/emacs-lisp/cl-extra.el
@@ -743,6 +743,11 @@ This also does some trivial optimizations to make the form prettier."
(let* ((args (cl-macroexpand-body (cdr form) env)) (p args))
(while (and p (symbolp (car p))) (setq p (cddr p)))
(if p (cl-macroexpand-all (cons 'setf args)) (cons 'setq args))))
+ ((consp (car form))
+ (cl-macroexpand-all (list* 'funcall
+ (list 'function (car form))
+ (cdr form))
+ env))
(t (cons (car form) (cl-macroexpand-body (cdr form) env)))))
(defun cl-macroexpand-body (body &optional env)