]> git.eshelyaron.com Git - emacs.git/commitdiff
* lisp/emacs-lisp/cl-generic.el: Fix bug#49053 and bug#47454
authorStefan Monnier <monnier@iro.umontreal.ca>
Wed, 16 Jun 2021 16:53:59 +0000 (12:53 -0400)
committerStefan Monnier <monnier@iro.umontreal.ca>
Wed, 16 Jun 2021 16:53:59 +0000 (12:53 -0400)
(cl-generic-define-method): Shorten the time window where the symbol is
defined to `dummy`.

lisp/emacs-lisp/cl-generic.el

index 31aa0cb4f9c0919eaaf1da8197fb961f11d8c159..544704be387eb8a6ee701f77b240ee41f1871a60 100644 (file)
@@ -568,17 +568,17 @@ The set of acceptable TYPEs (also called \"specializers\") is defined
               (cons method mt)
             ;; Keep the ordering; important for methods with :extra qualifiers.
             (mapcar (lambda (x) (if (eq x (car me)) method x)) mt)))
-    (let ((sym (cl--generic-name generic))) ; Actual name (for aliases).
+    (let ((sym (cl--generic-name generic)) ; Actual name (for aliases).
+          ;; FIXME: Try to avoid re-constructing a new function if the old one
+          ;; is still valid (e.g. still empty method cache)?
+          (gfun (cl--generic-make-function generic)))
       (unless (symbol-function sym)
         (defalias sym 'dummy))   ;Record definition into load-history.
       (cl-pushnew `(cl-defmethod . ,(cl--generic-load-hist-format
                                      (cl--generic-name generic)
                                      qualifiers specializers))
                   current-load-list :test #'equal)
-      ;; FIXME: Try to avoid re-constructing a new function if the old one
-      ;; is still valid (e.g. still empty method cache)?
-      (let ((gfun (cl--generic-make-function generic))
-            ;; Prevent `defalias' from recording this as the definition site of
+      (let (;; Prevent `defalias' from recording this as the definition site of
             ;; the generic function.
             current-load-list
             ;; BEWARE!  Don't purify this function definition, since that leads