]> git.eshelyaron.com Git - emacs.git/commitdiff
(cconv-convert): Fix regression
authorStefan Monnier <monnier@iro.umontreal.ca>
Tue, 7 Feb 2023 23:03:22 +0000 (18:03 -0500)
committerStefan Monnier <monnier@iro.umontreal.ca>
Tue, 7 Feb 2023 23:03:22 +0000 (18:03 -0500)
* lisp/emacs-lisp/cconv.el (cconv-convert, cconv-analyze-form):
Since we can't always remove the wrapper, make sure the wrapper
accepts the expected calling convention (i.e. called with no args).

lisp/emacs-lisp/cconv.el

index e8d639903c1d428552bfa194ca7ab9b8314297c4..570c9e66060ee15904d9911018f9482b1be65cc2 100644 (file)
@@ -483,7 +483,7 @@ places where they originally did not directly appear."
             (bf (if (stringp (car body)) (cdr body) body))
             (if (when (eq 'interactive (car-safe (car bf)))
                   (gethash form cconv--interactive-form-funs)))
-            (wrapped (pcase if (`#'(lambda (_cconv--dummy) .,_) t) (_ nil)))
+            (wrapped (pcase if (`#'(lambda (&rest _cconv--dummy) .,_) t) (_ nil)))
             (cif (when if (cconv-convert if env extend)))
             (_ (pcase cif
                  ('nil nil)
@@ -747,7 +747,7 @@ This function does not return anything but instead fills the
          (let ((if (cadr (car bf))))
            (unless (macroexp-const-p if) ;Optimize this common case.
              (let ((f (if (eq 'function (car-safe if)) if
-                        `#'(lambda (_cconv--dummy) ,if))))
+                        `#'(lambda (&rest _cconv--dummy) ,if))))
                (setf (gethash form cconv--interactive-form-funs) f)
                (cconv-analyze-form f env))))))
      (cconv--analyze-function vrs body-forms env form))