diff options
| -rw-r--r-- | lisp/ChangeLog | 2 | ||||
| -rw-r--r-- | lisp/subr.el | 3 |
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 @@ | |||
| 1 | 2014-11-06 Stefan Monnier <monnier@iro.umontreal.ca> | 1 | 2014-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. |