summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/keyboard.c46
1 files changed, 11 insertions, 35 deletions
diff --git a/src/keyboard.c b/src/keyboard.c
index c4e44ba9e5e..5556e3d18be 100644
--- a/src/keyboard.c
+++ b/src/keyboard.c
@@ -282,7 +282,6 @@ Lisp_Object Qself_insert_command;
Lisp_Object Qforward_char;
Lisp_Object Qbackward_char;
Lisp_Object Qundefined;
-Lisp_Object Qdigit_argument, Qnegative_argument;
/* read_key_sequence stores here the command definition of the
key sequence that it reads. */
@@ -835,7 +834,7 @@ cmd_error (data)
Vstandard_output = Qt;
Vstandard_input = Qt;
Vexecuting_macro = Qnil;
- clear_prefix_arg ();
+ current_kboard->Vprefix_arg = Qnil;
cancel_echoing ();
/* Avoid unquittable loop if data contains a circular list. */
@@ -1190,16 +1189,6 @@ command_loop_1 ()
last_point_position = PT;
XSETBUFFER (last_point_position_buffer, prev_buffer);
- /* If we're building a prefix argument, override minus and digits. */
- if (current_kboard->prefix_partial && i == 1 && NATNUMP (keybuf[0]))
- {
- if (XFASTINT (keybuf[0]) == '-'
- && NILP (current_kboard->prefix_value))
- cmd = Qnegative_argument;
- else if (XFASTINT (keybuf[0]) >= '0' && XFASTINT (keybuf[0]) <= '9')
- cmd = Qdigit_argument;
- }
-
/* Execute the command. */
this_command = cmd;
@@ -1214,15 +1203,11 @@ command_loop_1 ()
bitch_at_user ();
current_kboard->defining_kbd_macro = Qnil;
update_mode_lines = 1;
- clear_prefix_arg ();
+ current_kboard->Vprefix_arg = Qnil;
}
else
{
- current_prefix_partial = current_kboard->prefix_partial;
- if (current_kboard->prefix_partial)
- finalize_prefix_arg ();
-
- if (NILP (Vprefix_arg) && ! no_direct)
+ if (NILP (current_kboard->Vprefix_arg) && ! no_direct)
{
/* Recognize some common commands in common situations and
do them directly. */
@@ -1345,7 +1330,7 @@ command_loop_1 ()
/* Here for a command that isn't executed directly */
nonundocount = 0;
- if (NILP (Vprefix_arg))
+ if (NILP (current_kboard->Vprefix_arg))
Fundo_boundary ();
Fcommand_execute (this_command, Qnil);
@@ -1369,7 +1354,7 @@ command_loop_1 ()
3) we want to leave this_command_key_count non-zero, so that
read_char will realize that it is re-reading a character, and
not echo it a second time. */
- if (NILP (Vprefix_arg) && !current_kboard->prefix_partial)
+ if (NILP (current_kboard->Vprefix_arg))
{
last_command = this_command;
cancel_echoing ();
@@ -1390,8 +1375,8 @@ command_loop_1 ()
finalize:
/* Install chars successfully executed in kbd macro. */
- if (!NILP (current_kboard->defining_kbd_macro) && NILP (Vprefix_arg)
- && !current_kboard->prefix_partial)
+ if (!NILP (current_kboard->defining_kbd_macro)
+ && NILP (current_kboard->Vprefix_arg))
finalize_kbd_macro_chars ();
#ifdef MULTI_KBOARD
@@ -5983,8 +5968,8 @@ Otherwise, that is done only if an arg is read using the minibuffer.")
struct backtrace backtrace;
extern int debug_on_next_call;
- prefixarg = Vprefix_arg;
- clear_prefix_arg ();
+ prefixarg = current_kboard->Vprefix_arg;
+ current_kboard->Vprefix_arg = Qnil;
Vcurrent_prefix_arg = prefixarg;
debug_on_next_call = 0;
@@ -6115,7 +6100,7 @@ DEFUN ("execute-extended-command", Fexecute_extended_command, Sexecute_extended_
UNGCPRO;
function = Fintern (function, Qnil);
- Vprefix_arg = prefixarg;
+ current_kboard->Vprefix_arg = prefixarg;
this_command = function;
return Fcommand_execute (function, Qt);
@@ -6601,10 +6586,7 @@ void
init_kboard (kb)
KBOARD *kb;
{
- kb->prefix_factor = Qnil;
- kb->prefix_value = Qnil;
- kb->prefix_sign = 1;
- kb->prefix_partial = 0;
+ kb->Vprefix_arg = Qnil;
kb->kbd_queue = Qnil;
kb->kbd_queue_has_data = 0;
kb->immediate_echo = 0;
@@ -6762,12 +6744,6 @@ syms_of_keyboard ()
Qundefined = intern ("undefined");
staticpro (&Qundefined);
- Qdigit_argument = intern ("digit-argument");
- staticpro (&Qdigit_argument);
-
- Qnegative_argument = intern ("negative-argument");
- staticpro (&Qnegative_argument);
-
Qpre_command_hook = intern ("pre-command-hook");
staticpro (&Qpre_command_hook);