]> git.eshelyaron.com Git - emacs.git/commitdiff
Give 'when-let' and 'when-let*' their own Edebug specification.
authorPhilipp Stephani <phst@google.com>
Sat, 22 May 2021 11:29:50 +0000 (13:29 +0200)
committerPhilipp Stephani <phst@google.com>
Sat, 22 May 2021 11:29:50 +0000 (13:29 +0200)
The Edebug specification of 'if-let' and 'if-let*' doesn't work if the
body is empty.  While that's a pathological case, it's not wrong per
se, and could arguably happen due to macro expansion.

* lisp/emacs-lisp/subr-x.el (when-let*, when-let): Don't reuse Edebug
specification from 'if-let*' and 'if-let'.

lisp/emacs-lisp/subr-x.el

index fb890509ad7a13d95d50b62e046377703de9a616..72406df0ff7c5b35da837cf7ae8fd70ded5507ad 100644 (file)
@@ -139,7 +139,9 @@ This is like `if-let' but doesn't handle a VARLIST of the form
   "Bind variables according to VARLIST and conditionally evaluate BODY.
 This is like `when-let' but doesn't handle a VARLIST of the form
 \(SYMBOL SOMETHING) specially."
-  (declare (indent 1) (debug if-let*))
+  (declare (indent 1)
+           (debug ((&rest [&or symbolp (symbolp form) (form)])
+                   body)))
   (list 'if-let* varlist (macroexp-progn body)))
 
 (defmacro and-let* (varlist &rest body)
@@ -190,7 +192,10 @@ Evaluate each binding in turn, stopping if a binding value is nil.
 If all are non-nil, return the value of the last form in BODY.
 
 The variable list SPEC is the same as in `if-let'."
-  (declare (indent 1) (debug if-let))
+  (declare (indent 1)
+           (debug ([&or (symbolp form)  ; must be first, Bug#48489
+                        (&rest [&or symbolp (symbolp form) (form)])]
+                   body)))
   (list 'if-let spec (macroexp-progn body)))
 
 (defsubst hash-table-empty-p (hash-table)