aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lisp/ChangeLog2
-rw-r--r--lisp/subr.el3
2 files changed, 4 insertions, 1 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 91a076e20e5..7dc4786aff5 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,5 +1,7 @@
12014-11-06 Stefan Monnier <monnier@iro.umontreal.ca> 12014-11-06 Stefan Monnier <monnier@iro.umontreal.ca>
2 2
3 * subr.el (pop): Don't call the getter twice (bug#18968).
4
3 * emacs-lisp/macroexp.el (macroexp--expand-all): Optimize away trivial 5 * emacs-lisp/macroexp.el (macroexp--expand-all): Optimize away trivial
4 uses of `funcall'. 6 uses of `funcall'.
5 7
diff --git a/lisp/subr.el b/lisp/subr.el
index 55ff739fec5..6ce02b79a0a 100644
--- a/lisp/subr.el
+++ b/lisp/subr.el
@@ -169,7 +169,8 @@ change the list."
169 ;; So we can use `pop' in the bootstrap before `gv' can be used. 169 ;; So we can use `pop' in the bootstrap before `gv' can be used.
170 (list 'prog1 place (list 'setq place (list 'cdr place))) 170 (list 'prog1 place (list 'setq place (list 'cdr place)))
171 (gv-letplace (getter setter) place 171 (gv-letplace (getter setter) place
172 `(prog1 ,getter ,(funcall setter `(cdr ,getter))))))) 172 (macroexp-let2 macroexp-copyable-p x getter
173 `(prog1 ,x ,(funcall setter `(cdr ,x))))))))
173 174
174(defmacro when (cond &rest body) 175(defmacro when (cond &rest body)
175 "If COND yields non-nil, do BODY, else return nil. 176 "If COND yields non-nil, do BODY, else return nil.