]> git.eshelyaron.com Git - emacs.git/commit
nadvice: Fix bug#61179
authorStefan Monnier <monnier@iro.umontreal.ca>
Sat, 4 Feb 2023 16:23:31 +0000 (11:23 -0500)
committerStefan Monnier <monnier@iro.umontreal.ca>
Sat, 4 Feb 2023 16:23:31 +0000 (11:23 -0500)
commitc39c26e33f6bb45479bbd1a80df8c97cf750a56a
tree0632a99a1c20488637fc7fe108c30bab7e3d5055
parent229d0772e235f51812ed8020a31f9a8de366c7ba
nadvice: Fix bug#61179

Advising interactive forms relies on the ability to distinguish
interactive forms that do nothing else than return a function.
So, be careful to preserve this info.
Furthermore, interactive forms are expected to be evaluated in
the lexical context captured by the closure to which they belong,
so be careful to preserve that context when manipulating those forms.

* lisp/emacs-lisp/cconv.el (cconv-convert, cconv-analyze-form) <lambda>:
Preserve the info that an interactive form does nothing else than
return a function.

* lisp/emacs-lisp/nadvice.el (advice--interactive-form-1): New function.
(advice--interactive-form): Use it.
(advice--make-interactive-form): Refine to also accept function values
quoted with `quote`.  Remove obsolete TODO.

* test/lisp/emacs-lisp/nadvice-tests.el: Don't disallow byte-compilation.
(advice-test-bug61179): New test.

* lisp/emacs-lisp/oclosure.el (cconv--interactive-helper): Allow
the `if` arg to be a form.
* lisp/simple.el (oclosure-interactive-form): Adjust accordingly.
lisp/emacs-lisp/cconv.el
lisp/emacs-lisp/nadvice.el
lisp/emacs-lisp/oclosure.el
lisp/simple.el
test/lisp/emacs-lisp/nadvice-tests.el