# HG changeset patch # User Richard M. Stallman # Date 888868953 0 # Node ID 396f070a80111532bc975d8113f64bb83f7524d0 # Parent bac070da6b6d98a53dc5af8c33fe9bed8aa8ebe9 Include syntax.h. (interrupt_signal): Save and restore gl_state around an immediate quit, in case debugger returns. diff -r bac070da6b6d -r 396f070a8011 src/keyboard.c --- a/src/keyboard.c Mon Mar 02 20:01:46 1998 +0000 +++ b/src/keyboard.c Mon Mar 02 20:02:33 1998 +0000 @@ -36,6 +36,7 @@ #include "disptab.h" #include "dispextern.h" #include "keyboard.h" +#include "syntax.h" #include "intervals.h" #include "blockinput.h" #include @@ -7081,6 +7082,44 @@ UNGCPRO; return make_event_array (i, keybuf); } + +DEFUN ("read-key-sequence-vector", Fread_key_sequence_vector, + Sread_key_sequence_vector, 1, 4, 0, + "Like `read-key-sequence' but always return a vector.") + (prompt, continue_echo, dont_downcase_last, can_return_switch_frame) + Lisp_Object prompt, continue_echo, dont_downcase_last; + Lisp_Object can_return_switch_frame; +{ + Lisp_Object keybuf[30]; + register int i; + struct gcpro gcpro1, gcpro2; + + if (!NILP (prompt)) + CHECK_STRING (prompt, 0); + QUIT; + + bzero (keybuf, sizeof keybuf); + GCPRO1 (keybuf[0]); + gcpro1.nvars = (sizeof keybuf/sizeof (keybuf[0])); + + if (NILP (continue_echo)) + { + this_command_key_count = 0; + this_single_command_key_start = 0; + } + + i = read_key_sequence (keybuf, (sizeof keybuf/sizeof (keybuf[0])), + prompt, ! NILP (dont_downcase_last), + ! NILP (can_return_switch_frame), 0); + + if (i == -1) + { + Vquit_flag = Qt; + QUIT; + } + UNGCPRO; + return Fvector (i, keybuf); +} DEFUN ("command-execute", Fcommand_execute, Scommand_execute, 1, 4, 0, "Execute CMD as an editor command.\n\ @@ -7437,18 +7476,26 @@ XVECTOR (this_command_keys)->contents); } +DEFUN ("this-command-keys-vector", Fthis_command_keys_vector, Sthis_command_keys_vector, 0, 0, 0, + "Return the key sequence that invoked this command, as a vector.") + () +{ + return Fvector (this_command_key_count, + XVECTOR (this_command_keys)->contents); +} + DEFUN ("this-single-command-keys", Fthis_single_command_keys, Sthis_single_command_keys, 0, 0, 0, "Return the key sequence that invoked this command.\n\ Unlike `this-command-keys', this function's value\n\ does not include prefix arguments.\n\ -The value is a string or a vector.") +The value is always a vector.") () { - return make_event_array (this_command_key_count - - this_single_command_key_start, - (XVECTOR (this_command_keys)->contents - + this_single_command_key_start)); + return Fvector (this_command_key_count + - this_single_command_key_start, + (XVECTOR (this_command_keys)->contents + + this_single_command_key_start)); } DEFUN ("reset-this-command-lengths", Freset_this_command_lengths, @@ -7775,9 +7822,17 @@ then quit right away. */ if (immediate_quit && NILP (Vinhibit_quit)) { + struct gl_state_s saved; + struct gcpro gcpro1, gcpro2, gcpro3, gcpro4; + immediate_quit = 0; sigfree (); + saved = gl_state; + GCPRO4 (saved.object, saved.global_code, + saved.current_syntax_table, saved.old_prop); Fsignal (Qquit, Qnil); + gl_state = saved; + UNGCPRO; } else /* Else request quit when it's safe */ @@ -8221,6 +8276,7 @@ defsubr (&Sevent_convert_list); defsubr (&Sread_key_sequence); + defsubr (&Sread_key_sequence_vector); defsubr (&Srecursive_edit); #ifdef HAVE_MOUSE defsubr (&Strack_mouse); @@ -8229,6 +8285,7 @@ defsubr (&Scommand_execute); defsubr (&Srecent_keys); defsubr (&Sthis_command_keys); + defsubr (&Sthis_command_keys_vector); defsubr (&Sthis_single_command_keys); defsubr (&Sreset_this_command_lengths); defsubr (&Ssuspend_emacs);