Mercurial > emacs
annotate src/callint.c @ 23323:0800a4f84757
(underlying_strftime):
Set the buffer to a nonzero value before calling
strftime, and check to see whether strftime has set the buffer to zero.
This lets us distinguish between an empty buffer and an error.
I'm installing this patch by hand now; it will be superseded whenever
the glibc sources are propagated back to fsf.org.
| author | Paul Eggert <eggert@twinsun.com> |
|---|---|
| date | Fri, 25 Sep 1998 21:40:23 +0000 |
| parents | 5f08a9f278b1 |
| children | 93f40b344070 |
| rev | line source |
|---|---|
| 407 | 1 /* Call a Lisp function interactively. |
|
20552
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
2 Copyright (C) 1985, 86, 93, 94, 95, 1997 Free Software Foundation, Inc. |
| 407 | 3 |
| 4 This file is part of GNU Emacs. | |
| 5 | |
| 6 GNU Emacs is free software; you can redistribute it and/or modify | |
| 7 it under the terms of the GNU General Public License as published by | |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
8 the Free Software Foundation; either version 2, or (at your option) |
| 407 | 9 any later version. |
| 10 | |
| 11 GNU Emacs is distributed in the hope that it will be useful, | |
| 12 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 GNU General Public License for more details. | |
| 15 | |
| 16 You should have received a copy of the GNU General Public License | |
| 17 along with GNU Emacs; see the file COPYING. If not, write to | |
|
14186
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14062
diff
changeset
|
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
|
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14062
diff
changeset
|
19 Boston, MA 02111-1307, USA. */ |
| 407 | 20 |
| 21 | |
|
4696
1fc792473491
Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents:
4046
diff
changeset
|
22 #include <config.h> |
| 407 | 23 #include "lisp.h" |
| 24 #include "buffer.h" | |
| 25 #include "commands.h" | |
| 516 | 26 #include "keyboard.h" |
| 407 | 27 #include "window.h" |
| 28 #include "mocklisp.h" | |
| 29 | |
| 30 extern char *index (); | |
| 31 | |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
32 extern Lisp_Object Qcursor_in_echo_area; |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
33 |
|
12117
3fa5b6e7ad4b
(current_prefix_partial): Deleted.
Karl Heuer <kwzh@gnu.org>
parents:
11911
diff
changeset
|
34 Lisp_Object Vcurrent_prefix_arg, Qminus, Qplus; |
| 407 | 35 Lisp_Object Qcall_interactively; |
| 36 Lisp_Object Vcommand_history; | |
| 37 | |
|
21721
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
38 extern Lisp_Object Vhistory_length; |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
39 |
| 407 | 40 Lisp_Object Vcommand_debug_status, Qcommand_debug_status; |
| 873 | 41 Lisp_Object Qenable_recursive_minibuffers; |
| 407 | 42 |
|
3975
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
43 /* Non-nil means treat the mark as active |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
44 even if mark_active is 0. */ |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
45 Lisp_Object Vmark_even_if_inactive; |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
46 |
|
10279
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
47 Lisp_Object Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook; |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
48 |
|
13447
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
49 Lisp_Object Qlist, Qlet, Qletx, Qsave_excursion; |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
50 static Lisp_Object preserved_fns; |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
51 |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
52 /* Marker used within call-interactively to refer to point. */ |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
53 static Lisp_Object point_marker; |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
54 |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
55 /* Buffer for the prompt text used in Fcall_interactively. */ |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
56 static char *callint_message; |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
57 |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
58 /* Allocated length of that buffer. */ |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
59 static int callint_message_size; |
|
10940
40a1812dcbad
(current_prefix_partial): New var.
Karl Heuer <kwzh@gnu.org>
parents:
10917
diff
changeset
|
60 |
| 407 | 61 /* This comment supplies the doc string for interactive, |
| 62 for make-docfile to see. We cannot put this in the real DEFUN | |
| 63 due to limits in the Unix cpp. | |
| 64 | |
| 65 DEFUN ("interactive", Ffoo, Sfoo, 0, 0, 0, | |
| 66 "Specify a way of parsing arguments for interactive use of a function.\n\ | |
| 67 For example, write\n\ | |
| 68 (defun foo (arg) \"Doc string\" (interactive \"p\") ...use arg...)\n\ | |
| 69 to make ARG be the prefix argument when `foo' is called as a command.\n\ | |
| 70 The \"call\" to `interactive' is actually a declaration rather than a function;\n\ | |
| 71 it tells `call-interactively' how to read arguments\n\ | |
| 72 to pass to the function.\n\ | |
| 73 When actually called, `interactive' just returns nil.\n\ | |
| 74 \n\ | |
| 75 The argument of `interactive' is usually a string containing a code letter\n\ | |
| 76 followed by a prompt. (Some code letters do not use I/O to get\n\ | |
| 77 the argument and do not need prompts.) To prompt for multiple arguments,\n\ | |
| 78 give a code letter, its prompt, a newline, and another code letter, etc.\n\ | |
| 79 Prompts are passed to format, and may use % escapes to print the\n\ | |
| 80 arguments that have already been read.\n\ | |
| 81 If the argument is not a string, it is evaluated to get a list of\n\ | |
| 82 arguments to pass to the function.\n\ | |
| 83 Just `(interactive)' means pass no args when calling interactively.\n\ | |
| 84 \nCode letters available are:\n\ | |
| 85 a -- Function name: symbol with a function definition.\n\ | |
| 86 b -- Name of existing buffer.\n\ | |
| 87 B -- Name of buffer, possibly nonexistent.\n\ | |
|
23301
5f08a9f278b1
(Fcall_interactively): Don't use input method when
Kenichi Handa <handa@m17n.org>
parents:
23064
diff
changeset
|
88 c -- Character (no input method is used).\n\ |
| 407 | 89 C -- Command name: symbol with interactive function definition.\n\ |
| 90 d -- Value of point as number. Does not do I/O.\n\ | |
| 91 D -- Directory name.\n\ | |
|
2048
8cf58355e8a1
(check_mark): Error if mark is not active.
Richard M. Stallman <rms@gnu.org>
parents:
1926
diff
changeset
|
92 e -- Parametrized event (i.e., one that's a list) that invoked this command.\n\ |
|
8cf58355e8a1
(check_mark): Error if mark is not active.
Richard M. Stallman <rms@gnu.org>
parents:
1926
diff
changeset
|
93 If used more than once, the Nth `e' returns the Nth parameterized event.\n\ |
|
8cf58355e8a1
(check_mark): Error if mark is not active.
Richard M. Stallman <rms@gnu.org>
parents:
1926
diff
changeset
|
94 This skips events that are integers or symbols.\n\ |
| 407 | 95 f -- Existing file name.\n\ |
| 96 F -- Possibly nonexistent file name.\n\ | |
|
17024
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
97 i -- Ignored, i.e. always nil. Does not do I/O.\n\ |
| 10756 | 98 k -- Key sequence (downcase the last event if needed to get a definition).\n\ |
| 99 K -- Key sequence to be redefined (do not downcase the last event).\n\ | |
| 407 | 100 m -- Value of mark as number. Does not do I/O.\n\ |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
101 M -- Any string. Inherits the current input method.\n\ |
| 407 | 102 n -- Number read using minibuffer.\n\ |
|
9342
fdccacaec145
(Finteractive): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9298
diff
changeset
|
103 N -- Raw prefix arg, or if none, do like code `n'.\n\ |
| 407 | 104 p -- Prefix arg converted to number. Does not do I/O.\n\ |
| 105 P -- Prefix arg in raw form. Does not do I/O.\n\ | |
| 106 r -- Region: point and mark as 2 numeric args, smallest first. Does no I/O.\n\ | |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
107 s -- Any string. Does not inherit the current input method.\n\ |
| 407 | 108 S -- Any symbol.\n\ |
| 109 v -- Variable name: symbol that is user-variable-p.\n\ | |
| 110 x -- Lisp expression read but not evaluated.\n\ | |
| 111 X -- Lisp expression read and evaluated.\n\ | |
|
17024
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
112 z -- Coding system.\n\ |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
113 Z -- Coding system, nil if no prefix arg.\n\ |
| 407 | 114 In addition, if the string begins with `*'\n\ |
| 115 then an error is signaled if the buffer is read-only.\n\ | |
| 116 This happens before reading any arguments.\n\ | |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
117 If the string begins with `@', then Emacs searches the key sequence\n\ |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
118 which invoked the command for its first mouse click (or any other\n\ |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
119 event which specifies a window), and selects that window before\n\ |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
120 reading any arguments. You may use both `@' and `*'; they are\n\ |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
121 processed in the order that they appear." */ |
| 407 | 122 |
| 123 /* ARGSUSED */ | |
| 124 DEFUN ("interactive", Finteractive, Sinteractive, 0, UNEVALLED, 0, | |
| 125 0 /* See immediately above */) | |
| 126 (args) | |
| 127 Lisp_Object args; | |
| 128 { | |
| 129 return Qnil; | |
| 130 } | |
| 131 | |
| 132 /* Quotify EXP: if EXP is constant, return it. | |
| 133 If EXP is not constant, return (quote EXP). */ | |
| 134 Lisp_Object | |
| 135 quotify_arg (exp) | |
| 136 register Lisp_Object exp; | |
| 137 { | |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
138 if (!INTEGERP (exp) && !STRINGP (exp) |
| 485 | 139 && !NILP (exp) && !EQ (exp, Qt)) |
| 407 | 140 return Fcons (Qquote, Fcons (exp, Qnil)); |
| 141 | |
| 142 return exp; | |
| 143 } | |
| 144 | |
| 145 /* Modify EXP by quotifying each element (except the first). */ | |
| 146 Lisp_Object | |
| 147 quotify_args (exp) | |
| 148 Lisp_Object exp; | |
| 149 { | |
| 150 register Lisp_Object tail; | |
| 151 register struct Lisp_Cons *ptr; | |
| 152 for (tail = exp; CONSP (tail); tail = ptr->cdr) | |
| 153 { | |
| 154 ptr = XCONS (tail); | |
| 155 ptr->car = quotify_arg (ptr->car); | |
| 156 } | |
| 157 return exp; | |
| 158 } | |
| 159 | |
| 160 char *callint_argfuns[] | |
| 161 = {"", "point", "mark", "region-beginning", "region-end"}; | |
| 162 | |
| 163 static void | |
| 164 check_mark () | |
| 165 { | |
|
6494
00475922df29
(check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6271
diff
changeset
|
166 Lisp_Object tem; |
|
00475922df29
(check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6271
diff
changeset
|
167 tem = Fmarker_buffer (current_buffer->mark); |
| 485 | 168 if (NILP (tem) || (XBUFFER (tem) != current_buffer)) |
| 407 | 169 error ("The mark is not set now"); |
|
4039
77cb08d1c4a5
(check_mark): Don't check mark-active unless in transient-mark-mode.
Roland McGrath <roland@gnu.org>
parents:
3975
diff
changeset
|
170 if (!NILP (Vtransient_mark_mode) && NILP (Vmark_even_if_inactive) |
|
77cb08d1c4a5
(check_mark): Don't check mark-active unless in transient-mark-mode.
Roland McGrath <roland@gnu.org>
parents:
3975
diff
changeset
|
171 && NILP (current_buffer->mark_active)) |
|
77cb08d1c4a5
(check_mark): Don't check mark-active unless in transient-mark-mode.
Roland McGrath <roland@gnu.org>
parents:
3975
diff
changeset
|
172 Fsignal (Qmark_inactive, Qnil); |
| 407 | 173 } |
| 174 | |
| 175 | |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
176 DEFUN ("call-interactively", Fcall_interactively, Scall_interactively, 1, 3, 0, |
| 407 | 177 "Call FUNCTION, reading args according to its interactive calling specs.\n\ |
|
12582
5f8972720e72
(Fcall_interactively): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
12228
diff
changeset
|
178 Return the value FUNCTION returns.\n\ |
| 407 | 179 The function contains a specification of how to do the argument reading.\n\ |
| 180 In the case of user-defined functions, this is specified by placing a call\n\ | |
| 181 to the function `interactive' at the top level of the function body.\n\ | |
| 182 See `interactive'.\n\ | |
| 183 \n\ | |
| 184 Optional second arg RECORD-FLAG non-nil\n\ | |
| 185 means unconditionally put this command in the command-history.\n\ | |
|
13843
f5bd72a6fe48
(Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
13764
diff
changeset
|
186 Otherwise, this is done only if an arg is read using the minibuffer.") |
|
14062
16a05061fee3
(Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents:
13843
diff
changeset
|
187 (function, record_flag, keys) |
|
16a05061fee3
(Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents:
13843
diff
changeset
|
188 Lisp_Object function, record_flag, keys; |
| 407 | 189 { |
| 190 Lisp_Object *args, *visargs; | |
| 191 unsigned char **argstrings; | |
| 192 Lisp_Object fun; | |
| 193 Lisp_Object funcar; | |
| 194 Lisp_Object specs; | |
| 195 Lisp_Object teml; | |
| 873 | 196 Lisp_Object enable; |
| 197 int speccount = specpdl_ptr - specpdl; | |
| 407 | 198 |
|
1383
54028d2538a4
* callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents:
1347
diff
changeset
|
199 /* The index of the next element of this_command_keys to examine for |
|
54028d2538a4
* callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents:
1347
diff
changeset
|
200 the 'e' interactive code. */ |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
201 int next_event; |
|
1383
54028d2538a4
* callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents:
1347
diff
changeset
|
202 |
| 407 | 203 Lisp_Object prefix_arg; |
| 204 unsigned char *string; | |
| 205 unsigned char *tem; | |
| 438 | 206 |
| 207 /* If varies[i] > 0, the i'th argument shouldn't just have its value | |
| 208 in this call quoted in the command history. It should be | |
| 209 recorded as a call to the function named callint_argfuns[varies[i]]. */ | |
| 407 | 210 int *varies; |
| 438 | 211 |
| 407 | 212 register int i, j; |
| 213 int count, foo; | |
| 214 char prompt1[100]; | |
| 215 char *tem1; | |
| 216 int arg_from_tty = 0; | |
| 217 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4; | |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
218 int key_count; |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
219 |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
220 if (NILP (keys)) |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
221 keys = this_command_keys, key_count = this_command_key_count; |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
222 else |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
223 { |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
224 CHECK_VECTOR (keys, 3); |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
225 key_count = XVECTOR (keys)->size; |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
226 } |
| 407 | 227 |
| 732 | 228 /* Save this now, since use of minibuffer will clobber it. */ |
|
10857
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
229 prefix_arg = Vcurrent_prefix_arg; |
| 407 | 230 |
| 617 | 231 retry: |
| 407 | 232 |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
233 if (SYMBOLP (function)) |
|
1115
eb7f1ab33a9d
* callint.c (Fcall_interactively): Remove the 'K' interactive
Jim Blandy <jimb@redhat.com>
parents:
1084
diff
changeset
|
234 enable = Fget (function, Qenable_recursive_minibuffers); |
| 873 | 235 |
| 648 | 236 fun = indirect_function (function); |
| 407 | 237 |
| 238 specs = Qnil; | |
| 239 string = 0; | |
| 240 | |
| 241 /* Decode the kind of function. Either handle it and return, | |
| 242 or go to `lose' if not interactive, or go to `retry' | |
| 243 to specify a different function, or set either STRING or SPECS. */ | |
| 244 | |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
245 if (SUBRP (fun)) |
| 407 | 246 { |
| 247 string = (unsigned char *) XSUBR (fun)->prompt; | |
| 248 if (!string) | |
| 249 { | |
| 250 lose: | |
|
1926
952f2a18f83d
* callint.c (Fcall_interactively): Pass the correct number of
Jim Blandy <jimb@redhat.com>
parents:
1821
diff
changeset
|
251 function = wrong_type_argument (Qcommandp, function); |
| 407 | 252 goto retry; |
| 253 } | |
|
8819
18e94112cf67
(Fcall_interactively): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents:
7912
diff
changeset
|
254 if ((EMACS_INT) string == 1) |
| 407 | 255 /* Let SPECS (which is nil) be used as the args. */ |
| 256 string = 0; | |
| 257 } | |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
258 else if (COMPILEDP (fun)) |
| 407 | 259 { |
| 10345 | 260 if ((XVECTOR (fun)->size & PSEUDOVECTOR_SIZE_MASK) <= COMPILED_INTERACTIVE) |
| 407 | 261 goto lose; |
| 262 specs = XVECTOR (fun)->contents[COMPILED_INTERACTIVE]; | |
| 263 } | |
| 264 else if (!CONSP (fun)) | |
| 265 goto lose; | |
| 266 else if (funcar = Fcar (fun), EQ (funcar, Qautoload)) | |
| 267 { | |
| 268 GCPRO2 (function, prefix_arg); | |
| 269 do_autoload (fun, function); | |
| 270 UNGCPRO; | |
| 271 goto retry; | |
| 272 } | |
| 273 else if (EQ (funcar, Qlambda)) | |
| 274 { | |
| 275 specs = Fassq (Qinteractive, Fcdr (Fcdr (fun))); | |
| 485 | 276 if (NILP (specs)) |
| 407 | 277 goto lose; |
| 278 specs = Fcar (Fcdr (specs)); | |
| 279 } | |
| 280 else if (EQ (funcar, Qmocklisp)) | |
|
10846
b8ea4de9a069
(Fcall_interactively): Lock the display before executing the command, no
Karl Heuer <kwzh@gnu.org>
parents:
10819
diff
changeset
|
281 { |
|
11345
c4adea8f7543
(Fcall_interactively): Call single_kboard_state
Richard M. Stallman <rms@gnu.org>
parents:
11280
diff
changeset
|
282 single_kboard_state (); |
|
10846
b8ea4de9a069
(Fcall_interactively): Lock the display before executing the command, no
Karl Heuer <kwzh@gnu.org>
parents:
10819
diff
changeset
|
283 return ml_apply (fun, Qinteractive); |
|
b8ea4de9a069
(Fcall_interactively): Lock the display before executing the command, no
Karl Heuer <kwzh@gnu.org>
parents:
10819
diff
changeset
|
284 } |
| 407 | 285 else |
| 286 goto lose; | |
| 287 | |
| 617 | 288 /* If either specs or string is set to a string, use it. */ |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
289 if (STRINGP (specs)) |
| 617 | 290 { |
| 291 /* Make a copy of string so that if a GC relocates specs, | |
| 292 `string' will still be valid. */ | |
|
21244
50929073a0ba
Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents:
20635
diff
changeset
|
293 string = (unsigned char *) alloca (STRING_BYTES (XSTRING (specs)) + 1); |
|
50929073a0ba
Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents:
20635
diff
changeset
|
294 bcopy (XSTRING (specs)->data, string, |
|
50929073a0ba
Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents:
20635
diff
changeset
|
295 STRING_BYTES (XSTRING (specs)) + 1); |
| 617 | 296 } |
| 407 | 297 else if (string == 0) |
| 298 { | |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
299 Lisp_Object input; |
|
17876
6e27f660a0be
(Fcall_interactively): Use num_input_events.
Richard M. Stallman <rms@gnu.org>
parents:
17806
diff
changeset
|
300 i = num_input_events; |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
301 input = specs; |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
302 /* Compute the arg values using the user's expression. */ |
|
13843
f5bd72a6fe48
(Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
13764
diff
changeset
|
303 specs = Feval (specs); |
|
17876
6e27f660a0be
(Fcall_interactively): Use num_input_events.
Richard M. Stallman <rms@gnu.org>
parents:
17806
diff
changeset
|
304 if (i != num_input_events || !NILP (record_flag)) |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
305 { |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
306 /* We should record this command on the command history. */ |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
307 Lisp_Object values, car; |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
308 /* Make a copy of the list of values, for the command history, |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
309 and turn them into things we can eval. */ |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
310 values = quotify_args (Fcopy_sequence (specs)); |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
311 /* If the list of args was produced with an explicit call to `list', |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
312 look for elements that were computed with (region-beginning) |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
313 or (region-end), and put those expressions into VALUES |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
314 instead of the present values. */ |
|
13447
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
315 if (CONSP (input)) |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
316 { |
|
13447
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
317 car = XCONS (input)->car; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
318 /* Skip through certain special forms. */ |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
319 while (EQ (car, Qlet) || EQ (car, Qletx) |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
320 || EQ (car, Qsave_excursion)) |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
321 { |
|
13447
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
322 while (CONSP (XCONS (input)->cdr)) |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
323 input = XCONS (input)->cdr; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
324 input = XCONS (input)->car; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
325 if (!CONSP (input)) |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
326 break; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
327 car = XCONS (input)->car; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
328 } |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
329 if (EQ (car, Qlist)) |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
330 { |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
331 Lisp_Object intail, valtail; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
332 for (intail = Fcdr (input), valtail = values; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
333 CONSP (valtail); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
334 intail = Fcdr (intail), valtail = Fcdr (valtail)) |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
335 { |
|
13447
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
336 Lisp_Object elt; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
337 elt = Fcar (intail); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
338 if (CONSP (elt)) |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
339 { |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
340 Lisp_Object presflag; |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
341 presflag = Fmemq (Fcar (elt), preserved_fns); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
342 if (!NILP (presflag)) |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
343 Fsetcar (valtail, Fcar (intail)); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
344 } |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
345 } |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
346 } |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
347 } |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
348 Vcommand_history |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
349 = Fcons (Fcons (function, values), Vcommand_history); |
|
21721
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
350 |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
351 /* Don't keep command history around forever. */ |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
352 if (NUMBERP (Vhistory_length) && XINT (Vhistory_length) > 0) |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
353 { |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
354 teml = Fnthcdr (Vhistory_length, Vcommand_history); |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
355 if (CONSP (teml)) |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
356 XCONS (teml)->cdr = Qnil; |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
357 } |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
358 } |
|
11345
c4adea8f7543
(Fcall_interactively): Call single_kboard_state
Richard M. Stallman <rms@gnu.org>
parents:
11280
diff
changeset
|
359 single_kboard_state (); |
| 407 | 360 return apply1 (function, specs); |
| 361 } | |
| 362 | |
| 363 /* Here if function specifies a string to control parsing the defaults */ | |
| 364 | |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
365 /* Set next_event to point to the first event with parameters. */ |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
366 for (next_event = 0; next_event < key_count; next_event++) |
|
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
367 if (EVENT_HAS_PARAMETERS (XVECTOR (keys)->contents[next_event])) |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
368 break; |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
369 |
|
7912
f87185e63bbc
(Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
370 /* Handle special starting chars `*' and `@'. Also `-'. */ |
|
11278
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
371 /* Note that `+' is reserved for user extensions. */ |
| 407 | 372 while (1) |
| 373 { | |
|
11280
5146fba1f75d
(Fcall_interactively): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11278
diff
changeset
|
374 if (*string == '+') |
|
11278
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
375 error ("`+' is not used in `interactive' for ordinary commands"); |
|
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
376 else if (*string == '*') |
| 407 | 377 { |
| 378 string++; | |
| 485 | 379 if (!NILP (current_buffer->read_only)) |
| 407 | 380 Fbarf_if_buffer_read_only (); |
| 381 } | |
|
7912
f87185e63bbc
(Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
382 /* Ignore this for semi-compatibility with Lucid. */ |
|
f87185e63bbc
(Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
383 else if (*string == '-') |
|
f87185e63bbc
(Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
384 string++; |
| 407 | 385 else if (*string == '@') |
| 386 { | |
|
6494
00475922df29
(check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6271
diff
changeset
|
387 Lisp_Object event; |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
388 |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
389 event = XVECTOR (keys)->contents[next_event]; |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
390 if (EVENT_HAS_PARAMETERS (event) |
|
11371
b945fc51a3b6
(Fcall_interactively): Fix handling of @
Richard M. Stallman <rms@gnu.org>
parents:
11345
diff
changeset
|
391 && (event = XCONS (event)->cdr, CONSP (event)) |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
392 && (event = XCONS (event)->car, CONSP (event)) |
| 11419 | 393 && (event = XCONS (event)->car, WINDOWP (event))) |
|
6270
853b88dd9945
(Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents:
4696
diff
changeset
|
394 { |
| 6271 | 395 if (MINI_WINDOW_P (XWINDOW (event)) |
|
7912
f87185e63bbc
(Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
396 && ! (minibuf_level > 0 && EQ (event, minibuf_window))) |
|
6270
853b88dd9945
(Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents:
4696
diff
changeset
|
397 error ("Attempt to select inactive minibuffer window"); |
|
10279
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
398 |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
399 /* If the current buffer wants to clean up, let it. */ |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
400 if (!NILP (Vmouse_leave_buffer_hook)) |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
401 call1 (Vrun_hooks, Qmouse_leave_buffer_hook); |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
402 |
|
6270
853b88dd9945
(Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents:
4696
diff
changeset
|
403 Fselect_window (event); |
|
853b88dd9945
(Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents:
4696
diff
changeset
|
404 } |
| 407 | 405 string++; |
| 406 } | |
| 407 else break; | |
| 408 } | |
| 409 | |
| 410 /* Count the number of arguments the interactive spec would have | |
| 411 us give to the function. */ | |
| 412 tem = string; | |
| 413 for (j = 0; *tem; j++) | |
| 414 { | |
| 415 /* 'r' specifications ("point and mark as 2 numeric args") | |
| 416 produce *two* arguments. */ | |
| 417 if (*tem == 'r') j++; | |
| 418 tem = (unsigned char *) index (tem, '\n'); | |
| 419 if (tem) | |
| 420 tem++; | |
| 421 else | |
| 422 tem = (unsigned char *) ""; | |
| 423 } | |
|
13843
f5bd72a6fe48
(Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
13764
diff
changeset
|
424 count = j; |
| 407 | 425 |
| 426 args = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object)); | |
| 427 visargs = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object)); | |
| 428 argstrings = (unsigned char **) alloca ((count + 1) * sizeof (char *)); | |
| 429 varies = (int *) alloca ((count + 1) * sizeof (int)); | |
| 430 | |
| 431 for (i = 0; i < (count + 1); i++) | |
| 432 { | |
| 433 args[i] = Qnil; | |
| 434 visargs[i] = Qnil; | |
| 435 varies[i] = 0; | |
| 436 } | |
| 437 | |
| 438 GCPRO4 (prefix_arg, function, *args, *visargs); | |
| 439 gcpro3.nvars = (count + 1); | |
| 440 gcpro4.nvars = (count + 1); | |
| 441 | |
| 873 | 442 if (!NILP (enable)) |
| 443 specbind (Qenable_recursive_minibuffers, Qt); | |
| 444 | |
| 407 | 445 tem = string; |
|
13843
f5bd72a6fe48
(Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
13764
diff
changeset
|
446 for (i = 1; *tem; i++) |
| 407 | 447 { |
| 448 strncpy (prompt1, tem + 1, sizeof prompt1 - 1); | |
| 449 prompt1[sizeof prompt1 - 1] = 0; | |
| 450 tem1 = index (prompt1, '\n'); | |
| 451 if (tem1) *tem1 = 0; | |
| 452 /* Fill argstrings with a vector of C strings | |
| 453 corresponding to the Lisp strings in visargs. */ | |
| 454 for (j = 1; j < i; j++) | |
| 455 argstrings[j] | |
|
20552
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
456 = (EQ (visargs[j], Qnil) |
|
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
457 ? (unsigned char *) "" |
|
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
458 : XSTRING (visargs[j])->data); |
| 407 | 459 |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
460 /* Process the format-string in prompt1, putting the output |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
461 into callint_message. Make callint_message bigger if necessary. |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
462 We don't use a buffer on the stack, because the contents |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
463 need to stay stable for a while. */ |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
464 while (1) |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
465 { |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
466 int nchars = doprnt (callint_message, callint_message_size, |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
467 prompt1, (char *)0, |
|
20552
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
468 j - 1, (char **) argstrings + 1); |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
469 if (nchars < callint_message_size) |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
470 break; |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
471 callint_message_size *= 2; |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
472 callint_message |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
473 = (char *) xrealloc (callint_message, callint_message_size); |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
474 } |
| 407 | 475 |
| 476 switch (*tem) | |
| 477 { | |
| 478 case 'a': /* Symbol defined as a function */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
479 visargs[i] = Fcompleting_read (build_string (callint_message), |
|
17736
8b30ef18c480
(Fcall_interactively): Pass new arg to
Richard M. Stallman <rms@gnu.org>
parents:
17024
diff
changeset
|
480 Vobarray, Qfboundp, Qt, |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
481 Qnil, Qnil, Qnil, Qnil); |
| 407 | 482 /* Passing args[i] directly stimulates compiler bug */ |
| 483 teml = visargs[i]; | |
| 484 args[i] = Fintern (teml, Qnil); | |
| 485 break; | |
| 486 | |
| 487 case 'b': /* Name of existing buffer */ | |
| 488 args[i] = Fcurrent_buffer (); | |
| 489 if (EQ (selected_window, minibuf_window)) | |
|
22244
41c88b9489c3
(Fcall_interactively): Pass new arg to Fother_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
21721
diff
changeset
|
490 args[i] = Fother_buffer (args[i], Qnil, Qnil); |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
491 args[i] = Fread_buffer (build_string (callint_message), args[i], Qt); |
| 407 | 492 break; |
| 493 | |
| 494 case 'B': /* Name of buffer, possibly nonexistent */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
495 args[i] = Fread_buffer (build_string (callint_message), |
|
22244
41c88b9489c3
(Fcall_interactively): Pass new arg to Fother_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
21721
diff
changeset
|
496 Fother_buffer (Fcurrent_buffer (), Qnil, Qnil), |
|
1347
ac3a893b9bb9
(Fcall_interactively): Pass 2nd arg to Fother_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
1115
diff
changeset
|
497 Qnil); |
| 407 | 498 break; |
| 499 | |
| 500 case 'c': /* Character */ | |
|
23301
5f08a9f278b1
(Fcall_interactively): Don't use input method when
Kenichi Handa <handa@m17n.org>
parents:
23064
diff
changeset
|
501 args[i] = Fread_char (build_string (callint_message), Qt); |
|
13754
8310d6085087
(Fcall_interactively): Don't log prompt strings.
Karl Heuer <kwzh@gnu.org>
parents:
13664
diff
changeset
|
502 message1_nolog ((char *) 0); |
| 407 | 503 /* Passing args[i] directly stimulates compiler bug */ |
| 504 teml = args[i]; | |
| 505 visargs[i] = Fchar_to_string (teml); | |
| 506 break; | |
| 507 | |
| 508 case 'C': /* Command: symbol with interactive function */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
509 visargs[i] = Fcompleting_read (build_string (callint_message), |
|
17736
8b30ef18c480
(Fcall_interactively): Pass new arg to
Richard M. Stallman <rms@gnu.org>
parents:
17024
diff
changeset
|
510 Vobarray, Qcommandp, |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
511 Qt, Qnil, Qnil, Qnil, Qnil); |
| 407 | 512 /* Passing args[i] directly stimulates compiler bug */ |
| 513 teml = visargs[i]; | |
| 514 args[i] = Fintern (teml, Qnil); | |
| 515 break; | |
| 516 | |
| 517 case 'd': /* Value of point. Does not do I/O. */ | |
|
20552
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
518 set_marker_both (point_marker, Qnil, PT, PT_BYTE); |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
519 args[i] = point_marker; |
| 407 | 520 /* visargs[i] = Qnil; */ |
| 521 varies[i] = 1; | |
| 522 break; | |
| 523 | |
| 524 case 'D': /* Directory name. */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
525 args[i] = Fread_file_name (build_string (callint_message), Qnil, |
| 407 | 526 current_buffer->directory, Qlambda, Qnil); |
| 527 break; | |
| 528 | |
| 529 case 'f': /* Existing file name. */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
530 args[i] = Fread_file_name (build_string (callint_message), |
| 407 | 531 Qnil, Qnil, Qlambda, Qnil); |
| 532 break; | |
| 533 | |
| 534 case 'F': /* Possibly nonexistent file name. */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
535 args[i] = Fread_file_name (build_string (callint_message), |
| 407 | 536 Qnil, Qnil, Qnil, Qnil); |
| 537 break; | |
| 538 | |
|
17024
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
539 case 'i': /* Ignore an argument -- Does not do I/O */ |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
540 varies[i] = -1; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
541 break; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
542 |
|
10540
161014ddd3c5
(Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents:
10345
diff
changeset
|
543 case 'k': /* Key sequence. */ |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
544 { |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
545 int speccount1 = specpdl_ptr - specpdl; |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
546 specbind (Qcursor_in_echo_area, Qt); |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
547 args[i] = Fread_key_sequence (build_string (callint_message), |
|
22932
0e0275920715
(Fcall_interactively): Pass new arg to Fread_key_sequence.
Richard M. Stallman <rms@gnu.org>
parents:
22485
diff
changeset
|
548 Qnil, Qnil, Qnil, Qnil); |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
549 unbind_to (speccount1, Qnil); |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
550 teml = args[i]; |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
551 visargs[i] = Fkey_description (teml); |
|
22485
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
552 |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
553 /* If the key sequence ends with a down-event, |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
554 discard the following up-event. */ |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
555 teml = Faref (args[i], make_number (XINT (Flength (args[i])) - 1)); |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
556 if (CONSP (teml)) |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
557 teml = XCONS (teml)->car; |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
558 if (SYMBOLP (teml)) |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
559 { |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
560 Lisp_Object tem2; |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
561 |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
562 teml = Fget (teml, intern ("event-symbol-elements")); |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
563 tem2 = Fmemq (intern ("down"), teml); |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
564 if (! NILP (tem2)) |
|
23064
32a7b4dc421e
(Fcall_interactively): Pass new args to Fread_event
Richard M. Stallman <rms@gnu.org>
parents:
22932
diff
changeset
|
565 Fread_event (Qnil, Qnil); |
|
22485
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
566 } |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
567 } |
|
10540
161014ddd3c5
(Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents:
10345
diff
changeset
|
568 break; |
|
161014ddd3c5
(Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents:
10345
diff
changeset
|
569 |
|
161014ddd3c5
(Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents:
10345
diff
changeset
|
570 case 'K': /* Key sequence to be defined. */ |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
571 { |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
572 int speccount1 = specpdl_ptr - specpdl; |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
573 specbind (Qcursor_in_echo_area, Qt); |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
574 args[i] = Fread_key_sequence (build_string (callint_message), |
|
22932
0e0275920715
(Fcall_interactively): Pass new arg to Fread_key_sequence.
Richard M. Stallman <rms@gnu.org>
parents:
22485
diff
changeset
|
575 Qnil, Qt, Qnil, Qnil); |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
576 teml = args[i]; |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
577 visargs[i] = Fkey_description (teml); |
|
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
578 unbind_to (speccount1, Qnil); |
|
22485
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
579 |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
580 /* If the key sequence ends with a down-event, |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
581 discard the following up-event. */ |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
582 teml = Faref (args[i], make_number (XINT (Flength (args[i])) - 1)); |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
583 if (CONSP (teml)) |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
584 teml = XCONS (teml)->car; |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
585 if (SYMBOLP (teml)) |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
586 { |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
587 Lisp_Object tem2; |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
588 |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
589 teml = Fget (teml, intern ("event-symbol-elements")); |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
590 tem2 = Fmemq (intern ("down"), teml); |
|
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
591 if (! NILP (tem2)) |
|
23064
32a7b4dc421e
(Fcall_interactively): Pass new args to Fread_event
Richard M. Stallman <rms@gnu.org>
parents:
22932
diff
changeset
|
592 Fread_event (Qnil, Qnil); |
|
22485
b469abbc9984
(Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents:
22383
diff
changeset
|
593 } |
|
16363
4097c59143f8
(Fcall_interactively): Bind cursor-in-echo-area to t for `k' and `K'.
Richard M. Stallman <rms@gnu.org>
parents:
16039
diff
changeset
|
594 } |
| 407 | 595 break; |
| 596 | |
|
1383
54028d2538a4
* callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents:
1347
diff
changeset
|
597 case 'e': /* The invoking event. */ |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
598 if (next_event >= key_count) |
|
1383
54028d2538a4
* callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents:
1347
diff
changeset
|
599 error ("%s must be bound to an event with parameters", |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
600 (SYMBOLP (function) |
| 438 | 601 ? (char *) XSYMBOL (function)->name->data |
|
1383
54028d2538a4
* callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents:
1347
diff
changeset
|
602 : "command")); |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
603 args[i] = XVECTOR (keys)->contents[next_event++]; |
| 732 | 604 varies[i] = -1; |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
605 |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
606 /* Find the next parameterized event. */ |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
607 while (next_event < key_count |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
608 && ! (EVENT_HAS_PARAMETERS |
|
13308
99457b67e20c
(Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents:
13142
diff
changeset
|
609 (XVECTOR (keys)->contents[next_event]))) |
|
1821
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
610 next_event++; |
|
04fb1d3d6992
JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents:
1693
diff
changeset
|
611 |
| 438 | 612 break; |
| 613 | |
| 407 | 614 case 'm': /* Value of mark. Does not do I/O. */ |
| 615 check_mark (); | |
| 616 /* visargs[i] = Qnil; */ | |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
617 args[i] = current_buffer->mark; |
| 407 | 618 varies[i] = 2; |
| 619 break; | |
| 620 | |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
621 case 'M': /* String read via minibuffer with |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
622 inheriting the current input method. */ |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
623 args[i] = Fread_string (build_string (callint_message), |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
624 Qnil, Qnil, Qnil, Qt); |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
625 break; |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
626 |
| 407 | 627 case 'N': /* Prefix arg, else number from minibuffer */ |
| 485 | 628 if (!NILP (prefix_arg)) |
| 407 | 629 goto have_prefix_arg; |
| 630 case 'n': /* Read number from minibuffer. */ | |
|
15961
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
631 { |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
632 int first = 1; |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
633 do |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
634 { |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
635 Lisp_Object tem; |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
636 if (! first) |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
637 { |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
638 message ("Please enter a number."); |
|
17958
31bda055d8fe
(Fcall_interactively): Pass new arg to sit_for.
Richard M. Stallman <rms@gnu.org>
parents:
17876
diff
changeset
|
639 sit_for (1, 0, 0, 0, 0); |
|
15961
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
640 } |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
641 first = 0; |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
642 |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
643 tem = Fread_from_minibuffer (build_string (callint_message), |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
644 Qnil, Qnil, Qnil, Qnil, Qnil, |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
645 Qnil); |
|
15961
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
646 if (! STRINGP (tem) || XSTRING (tem)->size == 0) |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
647 args[i] = Qnil; |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
648 else |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
649 args[i] = Fread (tem); |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
650 } |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
651 while (! NUMBERP (args[i])); |
|
e26f5c2b75a6
(Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents:
14847
diff
changeset
|
652 } |
| 407 | 653 visargs[i] = last_minibuf_string; |
| 654 break; | |
| 655 | |
| 656 case 'P': /* Prefix arg in raw form. Does no I/O. */ | |
| 657 args[i] = prefix_arg; | |
| 658 /* visargs[i] = Qnil; */ | |
| 659 varies[i] = -1; | |
| 660 break; | |
| 661 | |
| 662 case 'p': /* Prefix arg converted to number. No I/O. */ | |
|
13764
db7fb833ba03
(Fcall_interactively): Handle an arg of form (FCN ARGS...).
Karl Heuer <kwzh@gnu.org>
parents:
13754
diff
changeset
|
663 have_prefix_arg: |
| 407 | 664 args[i] = Fprefix_numeric_value (prefix_arg); |
| 665 /* visargs[i] = Qnil; */ | |
| 666 varies[i] = -1; | |
| 667 break; | |
| 668 | |
| 669 case 'r': /* Region, point and mark as 2 args. */ | |
| 670 check_mark (); | |
|
20552
1a0cb8cd5615
(Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents:
19759
diff
changeset
|
671 set_marker_both (point_marker, Qnil, PT, PT_BYTE); |
| 407 | 672 /* visargs[i+1] = Qnil; */ |
| 673 foo = marker_position (current_buffer->mark); | |
| 674 /* visargs[i] = Qnil; */ | |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15961
diff
changeset
|
675 args[i] = PT < foo ? point_marker : current_buffer->mark; |
| 407 | 676 varies[i] = 3; |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15961
diff
changeset
|
677 args[++i] = PT > foo ? point_marker : current_buffer->mark; |
| 407 | 678 varies[i] = 4; |
| 679 break; | |
| 680 | |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
681 case 's': /* String read via minibuffer without |
|
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
682 inheriting the current input method. */ |
|
17806
96eb40f791e4
(Fcall_interactively): Pass extra arg to Fread_string.
Richard M. Stallman <rms@gnu.org>
parents:
17736
diff
changeset
|
683 args[i] = Fread_string (build_string (callint_message), |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
684 Qnil, Qnil, Qnil, Qnil); |
| 407 | 685 break; |
| 686 | |
| 687 case 'S': /* Any symbol. */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
688 visargs[i] = Fread_string (build_string (callint_message), |
|
19548
b275154db0cb
(Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents:
17958
diff
changeset
|
689 Qnil, Qnil, Qnil, Qnil); |
| 407 | 690 /* Passing args[i] directly stimulates compiler bug */ |
| 691 teml = visargs[i]; | |
| 692 args[i] = Fintern (teml, Qnil); | |
| 693 break; | |
| 694 | |
| 695 case 'v': /* Variable name: symbol that is | |
| 696 user-variable-p. */ | |
|
17736
8b30ef18c480
(Fcall_interactively): Pass new arg to
Richard M. Stallman <rms@gnu.org>
parents:
17024
diff
changeset
|
697 args[i] = Fread_variable (build_string (callint_message), Qnil); |
| 407 | 698 visargs[i] = last_minibuf_string; |
| 699 break; | |
| 700 | |
| 701 case 'x': /* Lisp expression read but not evaluated */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
702 args[i] = Fread_minibuffer (build_string (callint_message), Qnil); |
| 407 | 703 visargs[i] = last_minibuf_string; |
| 704 break; | |
| 705 | |
| 706 case 'X': /* Lisp expression read and evaluated */ | |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
707 args[i] = Feval_minibuffer (build_string (callint_message), Qnil); |
| 407 | 708 visargs[i] = last_minibuf_string; |
| 709 break; | |
| 710 | |
|
17024
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
711 case 'Z': /* Coding-system symbol, or ignore the |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
712 argument if no prefix */ |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
713 if (NILP (prefix_arg)) |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
714 { |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
715 args[i] = Qnil; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
716 varies[i] = -1; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
717 } |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
718 else |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
719 { |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
720 args[i] |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
721 = Fread_non_nil_coding_system (build_string (callint_message)); |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
722 visargs[i] = last_minibuf_string; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
723 } |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
724 break; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
725 |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
726 case 'z': /* Coding-system symbol or nil */ |
|
19759
8dbed9d176fe
(Fcall_interactively): Pass new arg to Fread_coding_system.
Richard M. Stallman <rms@gnu.org>
parents:
19548
diff
changeset
|
727 args[i] = Fread_coding_system (build_string (callint_message), Qnil); |
|
17024
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
728 visargs[i] = last_minibuf_string; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
729 break; |
|
6cfba7f41dca
(doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents:
16363
diff
changeset
|
730 |
|
11278
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
731 /* We have a case for `+' so we get an error |
|
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
732 if anyone tries to define one here. */ |
|
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
733 case '+': |
| 407 | 734 default: |
|
11278
25b2219c415c
(Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents:
11009
diff
changeset
|
735 error ("Invalid control letter `%c' (%03o) in interactive calling string", |
| 407 | 736 *tem, *tem); |
| 737 } | |
| 738 | |
| 739 if (varies[i] == 0) | |
| 740 arg_from_tty = 1; | |
| 741 | |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
742 if (NILP (visargs[i]) && STRINGP (args[i])) |
| 407 | 743 visargs[i] = args[i]; |
| 744 | |
| 745 tem = (unsigned char *) index (tem, '\n'); | |
| 746 if (tem) tem++; | |
| 747 else tem = (unsigned char *) ""; | |
| 748 } | |
| 873 | 749 unbind_to (speccount, Qnil); |
| 407 | 750 |
| 751 QUIT; | |
| 752 | |
| 753 args[0] = function; | |
| 754 | |
|
14062
16a05061fee3
(Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents:
13843
diff
changeset
|
755 if (arg_from_tty || !NILP (record_flag)) |
| 407 | 756 { |
| 757 visargs[0] = function; | |
| 438 | 758 for (i = 1; i < count + 1; i++) |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
759 { |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
760 if (varies[i] > 0) |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
761 visargs[i] = Fcons (intern (callint_argfuns[varies[i]]), Qnil); |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
762 else |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
763 visargs[i] = quotify_arg (args[i]); |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
764 } |
| 407 | 765 Vcommand_history = Fcons (Flist (count + 1, visargs), |
| 766 Vcommand_history); | |
|
21721
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
767 /* Don't keep command history around forever. */ |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
768 if (NUMBERP (Vhistory_length) && XINT (Vhistory_length) > 0) |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
769 { |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
770 teml = Fnthcdr (Vhistory_length, Vcommand_history); |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
771 if (CONSP (teml)) |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
772 XCONS (teml)->cdr = Qnil; |
|
46ffb5302c40
(Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents:
21514
diff
changeset
|
773 } |
| 407 | 774 } |
| 775 | |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
776 /* If we used a marker to hold point, mark, or an end of the region, |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
777 temporarily, convert it to an integer now. */ |
|
10917
283f18021929
(Fcall_interactively): Fix Feb 22 change.
Richard M. Stallman <rms@gnu.org>
parents:
10904
diff
changeset
|
778 for (i = 1; i <= count; i++) |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
779 if (varies[i] >= 1 && varies[i] <= 4) |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
780 XSETINT (args[i], marker_position (args[i])); |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
781 |
|
11345
c4adea8f7543
(Fcall_interactively): Call single_kboard_state
Richard M. Stallman <rms@gnu.org>
parents:
11280
diff
changeset
|
782 single_kboard_state (); |
|
10819
4768cffd88e5
(Fcall_interactively): If the display hasn't already been locked by reading
Karl Heuer <kwzh@gnu.org>
parents:
10803
diff
changeset
|
783 |
| 407 | 784 { |
| 785 Lisp_Object val; | |
| 786 specbind (Qcommand_debug_status, Qnil); | |
| 787 | |
| 788 val = Ffuncall (count + 1, args); | |
| 789 UNGCPRO; | |
| 790 return unbind_to (speccount, val); | |
| 791 } | |
| 792 } | |
| 793 | |
| 794 DEFUN ("prefix-numeric-value", Fprefix_numeric_value, Sprefix_numeric_value, | |
| 795 1, 1, 0, | |
|
14062
16a05061fee3
(Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents:
13843
diff
changeset
|
796 "Return numeric meaning of raw prefix argument RAW.\n\ |
| 407 | 797 A raw prefix argument is what you get from `(interactive \"P\")'.\n\ |
| 798 Its numeric meaning is what you would get from `(interactive \"p\")'.") | |
| 799 (raw) | |
| 800 Lisp_Object raw; | |
| 801 { | |
| 802 Lisp_Object val; | |
| 803 | |
| 485 | 804 if (NILP (raw)) |
|
9298
6e3aea54fc01
(Fcall_interactively, Fprefix_numeric_value): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents:
9290
diff
changeset
|
805 XSETFASTINT (val, 1); |
|
819
5bbabfcef929
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
732
diff
changeset
|
806 else if (EQ (raw, Qminus)) |
| 407 | 807 XSETINT (val, -1); |
|
12228
f4627b2f17dd
(Fprefix_numeric_value): Fix type check.
Karl Heuer <kwzh@gnu.org>
parents:
12117
diff
changeset
|
808 else if (CONSP (raw) && INTEGERP (XCONS (raw)->car)) |
| 407 | 809 XSETINT (val, XINT (XCONS (raw)->car)); |
|
9145
dda75a4dbbfb
(quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents:
9100
diff
changeset
|
810 else if (INTEGERP (raw)) |
| 407 | 811 val = raw; |
| 812 else | |
|
9298
6e3aea54fc01
(Fcall_interactively, Fprefix_numeric_value): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents:
9290
diff
changeset
|
813 XSETFASTINT (val, 1); |
| 407 | 814 |
| 815 return val; | |
| 816 } | |
| 817 | |
| 21514 | 818 void |
| 407 | 819 syms_of_callint () |
| 820 { | |
|
10803
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
821 point_marker = Fmake_marker (); |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
822 staticpro (&point_marker); |
|
b8c4a1b7d484
(Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents:
10756
diff
changeset
|
823 |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
824 preserved_fns = Fcons (intern ("region-beginning"), |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
825 Fcons (intern ("region-end"), |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
826 Fcons (intern ("point"), |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
827 Fcons (intern ("mark"), Qnil)))); |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
828 staticpro (&preserved_fns); |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
829 |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
830 Qlist = intern ("list"); |
|
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
831 staticpro (&Qlist); |
|
13447
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
832 Qlet = intern ("let"); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
833 staticpro (&Qlet); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
834 Qletx = intern ("let*"); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
835 staticpro (&Qletx); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
836 Qsave_excursion = intern ("save-excursion"); |
|
8c89b569cfa9
(syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents:
13308
diff
changeset
|
837 staticpro (&Qsave_excursion); |
|
1498
098464e977d6
(preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents:
1425
diff
changeset
|
838 |
| 407 | 839 Qminus = intern ("-"); |
| 840 staticpro (&Qminus); | |
| 841 | |
| 9100 | 842 Qplus = intern ("+"); |
| 843 staticpro (&Qplus); | |
| 844 | |
| 407 | 845 Qcall_interactively = intern ("call-interactively"); |
| 846 staticpro (&Qcall_interactively); | |
| 847 | |
| 848 Qcommand_debug_status = intern ("command-debug-status"); | |
| 849 staticpro (&Qcommand_debug_status); | |
| 850 | |
| 873 | 851 Qenable_recursive_minibuffers = intern ("enable-recursive-minibuffers"); |
| 852 staticpro (&Qenable_recursive_minibuffers); | |
| 853 | |
|
10279
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
854 Qmouse_leave_buffer_hook = intern ("mouse-leave-buffer-hook"); |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
855 staticpro (&Qmouse_leave_buffer_hook); |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
856 |
|
13142
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
857 callint_message_size = 100; |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
858 callint_message = (char *) xmalloc (callint_message_size); |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
859 |
|
297a0e21501a
(callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
12582
diff
changeset
|
860 |
|
12117
3fa5b6e7ad4b
(current_prefix_partial): Deleted.
Karl Heuer <kwzh@gnu.org>
parents:
11911
diff
changeset
|
861 DEFVAR_KBOARD ("prefix-arg", Vprefix_arg, |
|
10857
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
862 "The value of the prefix argument for the next editing command.\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
863 It may be a number, or the symbol `-' for just a minus sign as arg,\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
864 or a list whose car is a number for just one or more C-U's\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
865 or nil if no argument has been specified.\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
866 \n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
867 You cannot examine this variable to find the argument for this command\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
868 since it has been set to nil by the time you can look.\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
869 Instead, you should use the variable `current-prefix-arg', although\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
870 normally commands can get this prefix argument with (interactive \"P\")."); |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
871 |
|
22383
9ef0fe84c5ed
(syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
22244
diff
changeset
|
872 DEFVAR_KBOARD ("last-prefix-arg", Vlast_prefix_arg, |
|
9ef0fe84c5ed
(syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
22244
diff
changeset
|
873 "The value of the prefix argument for the previous editing command.\n\ |
|
9ef0fe84c5ed
(syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
22244
diff
changeset
|
874 See `prefix-arg' for the meaning of the value."); |
|
9ef0fe84c5ed
(syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
22244
diff
changeset
|
875 |
|
10857
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
876 DEFVAR_LISP ("current-prefix-arg", &Vcurrent_prefix_arg, |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
877 "The value of the prefix argument for this editing command.\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
878 It may be a number, or the symbol `-' for just a minus sign as arg,\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
879 or a list whose car is a number for just one or more C-U's\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
880 or nil if no argument has been specified.\n\ |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
881 This is what `(interactive \"P\")' returns."); |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
882 Vcurrent_prefix_arg = Qnil; |
|
2b9faff73319
(Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents:
10846
diff
changeset
|
883 |
| 407 | 884 DEFVAR_LISP ("command-history", &Vcommand_history, |
| 885 "List of recent commands that read arguments from terminal.\n\ | |
| 886 Each command is represented as a form to evaluate."); | |
| 887 Vcommand_history = Qnil; | |
| 888 | |
| 889 DEFVAR_LISP ("command-debug-status", &Vcommand_debug_status, | |
| 890 "Debugging status of current interactive command.\n\ | |
| 891 Bound each time `call-interactively' is called;\n\ | |
| 892 may be set by the debugger as a reminder for itself."); | |
| 893 Vcommand_debug_status = Qnil; | |
| 894 | |
|
4046
79184227e7f9
(syms_of_callint): Fix DEFVAR_LISP for Vmark_even_if_inactive to use right
Roland McGrath <roland@gnu.org>
parents:
4039
diff
changeset
|
895 DEFVAR_LISP ("mark-even-if-inactive", &Vmark_even_if_inactive, |
|
3975
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
896 "*Non-nil means you can use the mark even when inactive.\n\ |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
897 This option makes a difference in Transient Mark mode.\n\ |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
898 When the option is non-nil, deactivation of the mark\n\ |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
899 turns off region highlighting, but commands that use the mark\n\ |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
900 behave as if the mark were still active."); |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
901 Vmark_even_if_inactive = Qnil; |
|
718280a1ba74
(Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents:
2048
diff
changeset
|
902 |
|
10279
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
903 DEFVAR_LISP ("mouse-leave-buffer-hook", &Vmouse_leave_buffer_hook, |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
904 "Hook to run when about to switch windows with a mouse command.\n\ |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
905 Its purpose is to give temporary modes such as Isearch mode\n\ |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
906 a way to turn themselves off when a mouse command switches windows."); |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
907 Vmouse_leave_buffer_hook = Qnil; |
|
89cf458ed188
(Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
9342
diff
changeset
|
908 |
| 407 | 909 defsubr (&Sinteractive); |
| 910 defsubr (&Scall_interactively); | |
| 911 defsubr (&Sprefix_numeric_value); | |
| 912 } |
