# HG changeset patch # User Stefan Monnier # Date 962805675 0 # Node ID 70d9d51a864cfb7b7bc62ace9b8e3b59b9c0a113 # Parent ed1979c6dfb9d4246c9b60d9926cbe0af7aa1ef7 (show_help_echo): New function, extracted from read_char. Feval its `msg' argument if it's a cons cell. (read_char): Use it. (follow_key): Pass `autoload' to get_keyelt. diff -r ed1979c6dfb9 -r 70d9d51a864c src/keyboard.c --- a/src/keyboard.c Wed Jul 05 13:41:00 2000 +0000 +++ b/src/keyboard.c Wed Jul 05 14:01:15 2000 +0000 @@ -1895,6 +1895,35 @@ return c; } +/* Display a help message in the echo area. */ +void +show_help_echo (msg) + Lisp_Object msg; +{ + int count = specpdl_ptr - specpdl; + + specbind (Qmessage_truncate_lines, Qt); + if (CONSP (msg)) + msg = Feval (msg); + + if (!NILP (Vshow_help_function)) + call1 (Vshow_help_function, msg); + else if (/* Don't overwrite minibuffer contents. */ + !MINI_WINDOW_P (XWINDOW (selected_window)) + /* Don't overwrite a keystroke echo. */ + && NILP (echo_message_buffer) + /* Don't overwrite a prompt. */ + && !cursor_in_echo_area) + { + if (STRINGP (msg)) + message3_nolog (msg, XSTRING (msg)->size, STRING_MULTIBYTE (msg)); + else + message (0); + } + + unbind_to (count, Qnil); +} + /* Input of single characters from keyboard */ @@ -2639,28 +2668,7 @@ /* Display help if not echoing. */ if (CONSP (c) && EQ (XCAR (c), Qhelp_echo)) { - Lisp_Object msg; - int count = specpdl_ptr - specpdl; - - specbind (Qmessage_truncate_lines, Qt); - msg = XCDR (XCDR (c)); - - if (!NILP (Vshow_help_function)) - call1 (Vshow_help_function, msg); - else if (/* Don't overwrite minibuffer contents. */ - !MINI_WINDOW_P (XWINDOW (selected_window)) - /* Don't overwrite a keystroke echo. */ - && NILP (echo_message_buffer) - /* Don't overwrite a prompt. */ - && !cursor_in_echo_area) - { - if (STRINGP (msg)) - message3_nolog (msg, XSTRING (msg)->size, STRING_MULTIBYTE (msg)); - else - message (0); - } - - unbind_to (count, Qnil); + show_help_echo (XCDR (XCDR (c))); goto retry; } @@ -6266,7 +6274,7 @@ item = XCDR (item); } - /* Maybee key binding cache. */ + /* Maybe key binding cache. */ if (CONSP (item) && CONSP (XCAR (item)) && (NILP (XCAR (XCAR (item))) || VECTORP (XCAR (XCAR (item))))) @@ -7370,7 +7378,7 @@ else map = current[i]; - defs[i] = get_keyelt (access_keymap (map, key, 1, 0), 0); + defs[i] = get_keyelt (access_keymap (map, key, 1, 0), 1); if (! NILP (defs[i])) first_binding = i; }