mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-25 12:28:09 +01:00
emacs: help: add a special function to deal with remaps
remaps are a rather unusual keymap consisting of "first key" 'remap and then "second-key" the remapped-function. Thus we do the documentation for it separately.
This commit is contained in:
parent
8141555d25
commit
b5f93cc0db
1 changed files with 20 additions and 2 deletions
|
@ -260,6 +260,21 @@ It does not prepend if ACTUAL-KEY is already listed in TAIL."
|
|||
tail)))
|
||||
tail)
|
||||
|
||||
(defun notmuch-describe-remaps (remap-keymap ua-keys base-keymap prefix tail)
|
||||
;; Remappings are represented as a binding whose first "event" is
|
||||
;; 'remap. Hence, if the keymap has any remappings, it will have a
|
||||
;; binding whose "key" is 'remap, and whose "binding" is itself a
|
||||
;; keymap that maps not from keys to commands, but from old (remapped)
|
||||
;; functions to the commands to use in their stead.
|
||||
(map-keymap
|
||||
(lambda (command binding)
|
||||
(mapc
|
||||
(lambda (actual-key)
|
||||
(setq tail (notmuch-describe-key actual-key binding prefix ua-keys tail)))
|
||||
(where-is-internal command base-keymap)))
|
||||
remap-keymap)
|
||||
tail)
|
||||
|
||||
(defun notmuch-describe-keymap (keymap ua-keys base-keymap &optional prefix tail)
|
||||
"Return a list of cons cells, each describing one binding in KEYMAP.
|
||||
|
||||
|
@ -276,8 +291,11 @@ prefix argument. PREFIX and TAIL are used internally."
|
|||
(cond ((mouse-event-p key) nil)
|
||||
((keymapp binding)
|
||||
(setq tail
|
||||
(notmuch-describe-keymap
|
||||
binding ua-keys base-keymap (notmuch-prefix-key-description key) tail)))
|
||||
(if (eq key 'remap)
|
||||
(notmuch-describe-remaps
|
||||
binding ua-keys base-keymap prefix tail)
|
||||
(notmuch-describe-keymap
|
||||
binding ua-keys base-keymap (notmuch-prefix-key-description key) tail))))
|
||||
(binding
|
||||
(setq tail (notmuch-describe-key (vector key) binding prefix ua-keys tail)))))
|
||||
keymap)
|
||||
|
|
Loading…
Reference in a new issue