From: David Vázquez Date: Wed, 24 Apr 2013 23:14:51 +0000 (+0100) Subject: Speed up bootstrapping time without changing binding structure X-Git-Url: http://repo.macrolet.net/gitweb/?a=commitdiff_plain;h=111c32df145b2941e22d89634f89801b84fd32d2;p=jscl.git Speed up bootstrapping time without changing binding structure --- diff --git a/ecmalisp.lisp b/ecmalisp.lisp index cdd3a19..fab1811 100644 --- a/ecmalisp.lisp +++ b/ecmalisp.lisp @@ -2778,6 +2778,10 @@ b nil)))) +#+common-lisp +(defvar *macroexpander-cache* + (make-hash-table :test #'eq)) + (defun ls-macroexpand-1 (form) (cond ((symbolp form) @@ -2789,17 +2793,22 @@ (let ((macro-binding (macro (car form)))) (if macro-binding (let ((expander (binding-value macro-binding))) - (when (listp expander) - (let ((compiled (eval expander))) - ;; The list representation are useful while - ;; bootstrapping, as we can dump the definition of the - ;; macros easily, but they are slow because we have to - ;; evaluate them and compile them now and again. So, let - ;; us replace the list representation version of the - ;; function with the compiled one. - ;; - #+ecmalisp (setf (binding-value macro-binding) compiled) - (setq expander compiled))) + (cond + #+common-lisp + ((gethash macro-binding *macroexpander-cache*) + (setq expander (gethash macro-binding *macroexpander-cache*))) + ((listp expander) + (let ((compiled (eval expander))) + ;; The list representation are useful while + ;; bootstrapping, as we can dump the definition of the + ;; macros easily, but they are slow because we have to + ;; evaluate them and compile them now and again. So, let + ;; us replace the list representation version of the + ;; function with the compiled one. + ;; + #+ecmalisp (setf (binding-value macro-binding) compiled) + #+common-lisp (setf (gethash macro-binding *macroexpander-cache*) compiled) + (setq expander compiled)))) (values (apply expander (cdr form)) t)) (values form nil)))) (t