Mercurial > emacs
changeset 76862:4f957abd4298
(where_is_internal): Scan provided keymaps for command remappings
rather than calling Fcommand_remapping.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Sun, 01 Apr 2007 15:58:29 +0000 |
parents | 3f0c06049787 |
children | a5052885b6cb |
files | src/keymap.c |
diffstat | 1 files changed, 16 insertions(+), 9 deletions(-) [+] |
line wrap: on
line diff
--- a/src/keymap.c Sun Apr 01 15:42:39 2007 +0000 +++ b/src/keymap.c Sun Apr 01 15:58:29 2007 +0000 @@ -2579,15 +2579,6 @@ /* 1 means ignore all menu bindings entirely. */ int nomenus = !NILP (firstonly) && !EQ (firstonly, Qnon_ascii); - /* If this command is remapped, then it has no key bindings - of its own. */ - if (NILP (no_remap) && SYMBOLP (definition)) - { - Lisp_Object tem; - if (tem = Fcommand_remapping (definition, Qnil), !NILP (tem)) - return Qnil; - } - found = keymaps; while (CONSP (found)) { @@ -2601,6 +2592,22 @@ found = Qnil; sequences = Qnil; + /* If this command is remapped, then it has no key bindings + of its own. */ + if (NILP (no_remap) && SYMBOLP (definition)) + { + Lisp_Object kmaps, map, remap; + + for (kmaps = maps; !NILP (kmaps); kmaps = Fcdr (kmaps)) + if (map = Fcdr (Fcar (kmaps)), KEYMAPP (map)) + { + ASET (command_remapping_vector, 1, definition); + remap = Flookup_key (map, command_remapping_vector, Qnil); + if (!NILP (remap) && !INTEGERP (remap)) + RETURN_UNGCPRO (Qnil); + } + } + for (; !NILP (maps); maps = Fcdr (maps)) { /* Key sequence to reach map, and the map that it reaches */