summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp/generator.el
diff options
context:
space:
mode:
authorMattias EngdegÄrd <mattiase@acm.org>2021-11-30 15:04:46 +0100
committerMattias EngdegÄrd <mattiase@acm.org>2021-11-30 15:06:27 +0100
commit3966a28454dbc8ad0d20475325d5e03299025b57 (patch)
tree862a18e8dd232de6c5216346c3e9d17dbe01d261 /lisp/emacs-lisp/generator.el
parent5fb9a033f896440ffddeb475ee655413eb7f03f2 (diff)
downloademacs-3966a28454dbc8ad0d20475325d5e03299025b57.tar.gz
emacs-3966a28454dbc8ad0d20475325d5e03299025b57.tar.bz2
emacs-3966a28454dbc8ad0d20475325d5e03299025b57.zip
Generalise CPS-conversion let optimisation
* lisp/emacs-lisp/generator.el (cps--transform-1): Eliminate a temporary for the last of any `let` form, not just for single-binding ones. Suggested by Stefan Monnier.
Diffstat (limited to 'lisp/emacs-lisp/generator.el')
-rw-r--r--lisp/emacs-lisp/generator.el13
1 files changed, 6 insertions, 7 deletions
diff --git a/lisp/emacs-lisp/generator.el b/lisp/emacs-lisp/generator.el
index 4e286ed7ec4..cb0241017a0 100644
--- a/lisp/emacs-lisp/generator.el
+++ b/lisp/emacs-lisp/generator.el
@@ -294,26 +294,25 @@ DYNAMIC-VAR bound to STATIC-VAR."
(`(,(or 'let 'let*) () . ,body)
(cps--transform-1 `(progn ,@body) next-state))
- (`(let (,binding) . ,body)
- (cps--transform-1 `(let* (,binding) ,@body) next-state))
-
;; Transform multi-variable `let' into `let*':
;; (let ((v1 e1) ... (vN eN)) BODY)
- ;; -> (let* ((t1 e1) ... (tN eN) (v1 t1) (vN tN)) BODY)
+ ;; -> (let* ((t1 e1) ... (tN-1 eN-1) (vN eN) (v1 t1) (vN-1 tN-1)) BODY)
(`(let ,bindings . ,body)
(let* ((bindings (cl-loop for binding in bindings
collect (if (symbolp binding)
(list binding nil)
binding)))
- (temps (cl-loop for (var _value-form) in bindings
+ (butlast-bindings (butlast bindings))
+ (temps (cl-loop for (var _value-form) in butlast-bindings
collect (cps--add-binding var))))
(cps--transform-1
`(let* ,(append
- (cl-loop for (_var value-form) in bindings
+ (cl-loop for (_var value-form) in butlast-bindings
for temp in temps
collect (list temp value-form))
- (cl-loop for (var _binding) in bindings
+ (last bindings)
+ (cl-loop for (var _binding) in butlast-bindings
for temp in temps
collect (list var temp)))
,@body)