GNU bug report logs -
#46727
27.1; Only the first function from prefix-command-echo-keystrokes-functions is used
Previous Next
Reported by: Miha Rihtaršič <miha <at> kamnitnik.top>
Date: Tue, 23 Feb 2021 20:43:02 UTC
Severity: normal
Tags: fixed
Found in version 27.1
Fixed in version 28.1
Done: Lars Ingebrigtsen <larsi <at> gnus.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
Miha Rihtaršič <miha <at> kamnitnik.top> writes:
> Greetings.
>
> Looking at the function internal-echo-keystrokes-prefix, it is heavily
> implied that all functions from
> `prefix-command-echo-keystrokes-functions` should be used and their
> return values concatenated. This isn't the case, however, because
> `run-hook-wrapped` aborts on first non-nil returned value. The following
> simple patch fixes this.
[...]
> (run-hook-wrapped 'prefix-command-echo-keystrokes-functions
> - (lambda (fun) (push (funcall fun) strs)))
> + (lambda (fun) (push (funcall fun) strs) nil))
Thanks.
I poked around in the code, and I think your interpretation here must be
correct, and I've applied your patch to Emacs 28. (Besides, `push' has
an undefined return value... and always returns non-nil, so the old
code would, as you said, never use more than the first function in
`prefix-command-echo-keystrokes-functions'.)
This change was small enough to apply without assigning copyright to the
FSF, but for future patches you want to submit, it might make sense to
get the paperwork started now, so that subsequent patches can be applied
speedily. Would you be willing to sign such paperwork?
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
This bug report was last modified 4 years and 82 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.