diff options
author | Mattias EngdegÄrd <mattiase@acm.org> | 2021-11-30 15:04:46 +0100 |
---|---|---|
committer | Mattias EngdegÄrd <mattiase@acm.org> | 2021-11-30 15:06:27 +0100 |
commit | 3966a28454dbc8ad0d20475325d5e03299025b57 (patch) | |
tree | 862a18e8dd232de6c5216346c3e9d17dbe01d261 /lisp/emacs-lisp/generator.el | |
parent | 5fb9a033f896440ffddeb475ee655413eb7f03f2 (diff) | |
download | emacs-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.el | 13 |
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) |