From: Stefan Monnier Date: Sun, 14 Oct 2001 22:45:14 +0000 (+0000) Subject: (access_keymap): Unify handling of `t' and generic-char. X-Git-Tag: ttn-vms-21-2-B4~19434 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=845e4cf4d4ce8467528a9d96284052e42dc122b0;p=emacs.git (access_keymap): Unify handling of `t' and generic-char. If a parent is reached and noinherit is set, exit immediately. Use AREF and ASIZE macros. Call get_keyelt before checking KEYMAPP. --- diff --git a/src/ChangeLog b/src/ChangeLog index a4374db8a99..e59a04459f5 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,9 @@ 2001-10-14 Stefan Monnier + * keymap.c (access_keymap): Unify handling of `t' and generic-char. + If a parent is reached and noinherit is set, exit immediately. + Use AREF and ASIZE macros. Call get_keyelt before checking KEYMAPP. + * s/ms-w32.h (EXEC_SUFFIXES): * s/msdos.h (EXEC_SUFFIXES): * process.h (EXEC_SUFFIXES): Remove. diff --git a/src/keymap.c b/src/keymap.c index 50f27273c72..75a12ead3ca 100644 --- a/src/keymap.c +++ b/src/keymap.c @@ -476,8 +476,7 @@ access_keymap (map, idx, t_ok, noinherit, autoload) int noinherit; int autoload; { - int noprefix = 0; - Lisp_Object val; + Lisp_Object val = Qunbound; /* If idx is a list (some sort of mouse click, perhaps?), the index we want to use is the car of the list, which @@ -517,12 +516,13 @@ access_keymap (map, idx, t_ok, noinherit, autoload) { Lisp_Object tail; - Lisp_Object t_binding; - Lisp_Object generic_binding; + Lisp_Object t_binding = Qnil; + + /* If `t_ok' is 2, both `t' and generic-char bindings are accepted. + If it is 1, only generic-char bindings are accepted. + Otherwise, neither are. */ + t_ok = t_ok ? 2 : 0; - t_binding = Qnil; - generic_binding = Qnil; - for (tail = XCDR (map); (CONSP (tail) || (tail = get_keymap (tail, 0, autoload), CONSP (tail))); @@ -536,7 +536,7 @@ access_keymap (map, idx, t_ok, noinherit, autoload) /* If NOINHERIT, stop finding prefix definitions after we pass a second occurrence of the `keymap' symbol. */ if (noinherit && EQ (binding, Qkeymap)) - noprefix = 1; + return Qnil; } else if (CONSP (binding)) { @@ -544,15 +544,9 @@ access_keymap (map, idx, t_ok, noinherit, autoload) int c1, c2, charset; if (EQ (key, idx)) - { - val = XCDR (binding); - if (noprefix && KEYMAPP (val)) - return Qnil; - if (CONSP (val)) - fix_submap_inheritance (map, idx, val); - return get_keyelt (val, autoload); - } - else if (INTEGERP (idx) + val = XCDR (binding); + else if (t_ok + && INTEGERP (idx) && (XINT (idx) & CHAR_MODIFIER_MASK) == 0 && INTEGERP (key) && (XINT (key) & CHAR_MODIFIER_MASK) == 0 @@ -566,22 +560,19 @@ access_keymap (map, idx, t_ok, noinherit, autoload) /* KEY is the generic character of the charset of IDX. Use KEY's binding if there isn't a binding for IDX itself. */ - generic_binding = XCDR (binding); + t_binding = XCDR (binding); + t_ok = 0; + } + else if (t_ok > 1 && EQ (key, Qt)) + { + t_binding = XCDR (binding); + t_ok = 1; } - else if (t_ok && EQ (XCAR (binding), Qt)) - t_binding = XCDR (binding); } else if (VECTORP (binding)) { - if (NATNUMP (idx) && XFASTINT (idx) < XVECTOR (binding)->size) - { - val = XVECTOR (binding)->contents[XFASTINT (idx)]; - if (noprefix && KEYMAPP (val)) - return Qnil; - if (CONSP (val)) - fix_submap_inheritance (map, idx, val); - return get_keyelt (val, autoload); - } + if (NATNUMP (idx) && XFASTINT (idx) < ASIZE (binding)) + val = AREF (binding, XFASTINT (idx)); } else if (CHAR_TABLE_P (binding)) { @@ -590,22 +581,20 @@ access_keymap (map, idx, t_ok, noinherit, autoload) All character codes without modifiers are included. */ if (NATNUMP (idx) && (XFASTINT (idx) & CHAR_MODIFIER_MASK) == 0) - { - val = Faref (binding, idx); - if (noprefix && KEYMAPP (val)) - return Qnil; - if (CONSP (val)) - fix_submap_inheritance (map, idx, val); - return get_keyelt (val, autoload); - } + val = Faref (binding, idx); } + /* If we found a binding, clean it up and return it. */ + if (!EQ (val, Qunbound)) + { + val = get_keyelt (val, autoload); + if (KEYMAPP (val)) + fix_submap_inheritance (map, idx, val); + return val; + } QUIT; } - if (!NILP (generic_binding)) - return get_keyelt (generic_binding, autoload); - return get_keyelt (t_binding, autoload); } }