annotate src/callint.c @ 50780:3c9a6397c579

Update copyright and maintenance details. Update some package URLs, versions, and maintainers. Remove many references to the Emacs Lisp Archive as it is no longer being updated.
author Glenn Morris <rgm@gnu.org>
date Fri, 02 May 2003 21:59:58 +0000
parents 0bdc2fd19631
children 7ac9c3bea5ea
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
1 /* Call a Lisp function interactively.
44405
0ed69545b5f3 (Fcall_interactively): Use INTEGERP instead of
Gerd Moellmann <gerd@gnu.org>
parents: 43039
diff changeset
2 Copyright (C) 1985, 86, 93, 94, 95, 1997, 2000, 2002
34799
c04a8de55245 (Fcall_interactively): Prevent a compiler warning.
Gerd Moellmann <gerd@gnu.org>
parents: 31336
diff changeset
3 Free Software Foundation, Inc.
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
4
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
5 This file is part of GNU Emacs.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
6
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
7 GNU Emacs is free software; you can redistribute it and/or modify
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
8 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
9 the Free Software Foundation; either version 2, or (at your option)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
10 any later version.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
11
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
15 GNU General Public License for more details.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
16
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
18 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
19 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
20 Boston, MA 02111-1307, USA. */
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
21
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
22
4696
1fc792473491 Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents: 4046
diff changeset
23 #include <config.h>
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
24
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
25 #include "lisp.h"
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
26 #include "buffer.h"
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
27 #include "commands.h"
516
ccadad491483 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 485
diff changeset
28 #include "keyboard.h"
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
29 #include "window.h"
39697
0b986bb45526 Include keymap.h.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 34799
diff changeset
30 #include "keymap.h"
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
31
31336
3ecef4a7b3cd Remove includes of
Gerd Moellmann <gerd@gnu.org>
parents: 31225
diff changeset
32 #ifdef HAVE_INDEX
3ecef4a7b3cd Remove includes of
Gerd Moellmann <gerd@gnu.org>
parents: 31225
diff changeset
33 extern char *index P_ ((const char *, int));
31225
7930c46bb365 (toplevel) [HAVE_STRING_H]: Include string.h.
Gerd Moellmann <gerd@gnu.org>
parents: 29371
diff changeset
34 #endif
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
35
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
36 extern Lisp_Object Qcursor_in_echo_area;
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
37 extern Lisp_Object Qfile_directory_p;
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
38
12117
3fa5b6e7ad4b (current_prefix_partial): Deleted.
Karl Heuer <kwzh@gnu.org>
parents: 11911
diff changeset
39 Lisp_Object Vcurrent_prefix_arg, Qminus, Qplus;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
40 Lisp_Object Qcall_interactively;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
41 Lisp_Object Vcommand_history;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
42
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
43 extern Lisp_Object Vhistory_length;
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
44
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
45 Lisp_Object Vcommand_debug_status, Qcommand_debug_status;
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
46 Lisp_Object Qenable_recursive_minibuffers;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
47
3975
718280a1ba74 (Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 2048
diff changeset
48 /* 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
49 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
50 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
51
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
52 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
53
49932
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
54 Lisp_Object Qlist, Qlet, Qletx, Qsave_excursion, Qprogn, Qif, Qwhen;
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
55 static Lisp_Object preserved_fns;
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
56
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
57 /* 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
58 static Lisp_Object point_marker;
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
59
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
60 /* 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
61 static char *callint_message;
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
62
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
63 /* Allocated length of that buffer. */
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
64 static int callint_message_size;
10940
40a1812dcbad (current_prefix_partial): New var.
Karl Heuer <kwzh@gnu.org>
parents: 10917
diff changeset
65
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
66 /* ARGSUSED */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
67 DEFUN ("interactive", Finteractive, Sinteractive, 0, UNEVALLED, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
68 doc: /* Specify a way of parsing arguments for interactive use of a function.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
69 For example, write
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
70 (defun foo (arg) "Doc string" (interactive "p") ...use arg...)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
71 to make ARG be the prefix argument when `foo' is called as a command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
72 The "call" to `interactive' is actually a declaration rather than a function;
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
73 it tells `call-interactively' how to read arguments
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
74 to pass to the function.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
75 When actually called, `interactive' just returns nil.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
76
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
77 The argument of `interactive' is usually a string containing a code letter
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
78 followed by a prompt. (Some code letters do not use I/O to get
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
79 the argument and do not need prompts.) To prompt for multiple arguments,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
80 give a code letter, its prompt, a newline, and another code letter, etc.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
81 Prompts are passed to format, and may use % escapes to print the
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
82 arguments that have already been read.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
83 If the argument is not a string, it is evaluated to get a list of
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
84 arguments to pass to the function.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
85 Just `(interactive)' means pass no args when calling interactively.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
86
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
87 Code letters available are:
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
88 a -- Function name: symbol with a function definition.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
89 b -- Name of existing buffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
90 B -- Name of buffer, possibly nonexistent.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
91 c -- Character (no input method is used).
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
92 C -- Command name: symbol with interactive function definition.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
93 d -- Value of point as number. Does not do I/O.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
94 D -- Directory name.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
95 e -- Parametrized event (i.e., one that's a list) that invoked this command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
96 If used more than once, the Nth `e' returns the Nth parameterized event.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
97 This skips events that are integers or symbols.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
98 f -- Existing file name.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
99 F -- Possibly nonexistent file name.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
100 i -- Ignored, i.e. always nil. Does not do I/O.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
101 k -- Key sequence (downcase the last event if needed to get a definition).
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
102 K -- Key sequence to be redefined (do not downcase the last event).
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
103 m -- Value of mark as number. Does not do I/O.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
104 M -- Any string. Inherits the current input method.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
105 n -- Number read using minibuffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
106 N -- Raw prefix arg, or if none, do like code `n'.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
107 p -- Prefix arg converted to number. Does not do I/O.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
108 P -- Prefix arg in raw form. Does not do I/O.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
109 r -- Region: point and mark as 2 numeric args, smallest first. Does no I/O.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
110 s -- Any string. Does not inherit the current input method.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
111 S -- Any symbol.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
112 v -- Variable name: symbol that is user-variable-p.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
113 x -- Lisp expression read but not evaluated.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
114 X -- Lisp expression read and evaluated.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
115 z -- Coding system.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
116 Z -- Coding system, nil if no prefix arg.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
117 In addition, if the string begins with `*'
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
118 then an error is signaled if the buffer is read-only.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
119 This happens before reading any arguments.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
120 If the string begins with `@', then Emacs searches the key sequence
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
121 which invoked the command for its first mouse click (or any other
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
122 event which specifies a window), and selects that window before
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
123 reading any arguments. You may use both `@' and `*'; they are
40643
184e0d756547 (Finteractive): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 40103
diff changeset
124 processed in the order that they appear.
184e0d756547 (Finteractive): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 40103
diff changeset
125 usage: (interactive ARGS) */)
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
126 (args)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
127 Lisp_Object args;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
128 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
129 return Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
130 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
131
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
132 /* Quotify EXP: if EXP is constant, return it.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
133 If EXP is not constant, return (quote EXP). */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
134 Lisp_Object
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
135 quotify_arg (exp)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
136 register Lisp_Object exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
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
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
139 && !NILP (exp) && !EQ (exp, Qt))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
140 return Fcons (Qquote, Fcons (exp, Qnil));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
141
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
142 return exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
143 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
144
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
145 /* Modify EXP by quotifying each element (except the first). */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
146 Lisp_Object
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
147 quotify_args (exp)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
148 Lisp_Object exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
149 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
150 register Lisp_Object tail;
26164
d39ec0a27081 more XCAR/XCDR/XFLOAT_DATA uses, to help isolete lisp engine
Ken Raeburn <raeburn@raeburn.org>
parents: 25645
diff changeset
151 Lisp_Object next;
d39ec0a27081 more XCAR/XCDR/XFLOAT_DATA uses, to help isolete lisp engine
Ken Raeburn <raeburn@raeburn.org>
parents: 25645
diff changeset
152 for (tail = exp; CONSP (tail); tail = next)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
153 {
26164
d39ec0a27081 more XCAR/XCDR/XFLOAT_DATA uses, to help isolete lisp engine
Ken Raeburn <raeburn@raeburn.org>
parents: 25645
diff changeset
154 next = XCDR (tail);
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39945
diff changeset
155 XSETCAR (tail, quotify_arg (XCAR (tail)));
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
156 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
157 return exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
158 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
159
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
160 char *callint_argfuns[]
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
161 = {"", "point", "mark", "region-beginning", "region-end"};
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
162
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
163 static void
43039
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
164 check_mark (for_region)
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
165 int for_region;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
166 {
6494
00475922df29 (check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6271
diff changeset
167 Lisp_Object tem;
00475922df29 (check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6271
diff changeset
168 tem = Fmarker_buffer (current_buffer->mark);
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
169 if (NILP (tem) || (XBUFFER (tem) != current_buffer))
43039
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
170 error (for_region ? "The mark is not set now, so there is no region"
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
171 : "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
172 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
173 && 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
174 Fsignal (Qmark_inactive, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
175 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
176
50469
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
177 /* If the list of args INPUT was produced with an explicit call to
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
178 `list', look for elements that were computed with
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
179 (region-beginning) or (region-end), and put those expressions into
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
180 VALUES instead of the present values.
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
181
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
182 This function doesn't return a value because it modifies elements
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
183 of VALUES to do its job. */
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
184
49953
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
185 static void
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
186 fix_command (input, values)
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
187 Lisp_Object input, values;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
188 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
189 if (CONSP (input))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
190 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
191 Lisp_Object car;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
192
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
193 car = XCAR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
194 /* Skip through certain special forms. */
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
195 while (EQ (car, Qlet) || EQ (car, Qletx)
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
196 || EQ (car, Qsave_excursion)
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
197 || EQ (car, Qprogn))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
198 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
199 while (CONSP (XCDR (input)))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
200 input = XCDR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
201 input = XCAR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
202 if (!CONSP (input))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
203 break;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
204 car = XCAR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
205 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
206 if (EQ (car, Qlist))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
207 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
208 Lisp_Object intail, valtail;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
209 for (intail = Fcdr (input), valtail = values;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
210 CONSP (valtail);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
211 intail = Fcdr (intail), valtail = Fcdr (valtail))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
212 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
213 Lisp_Object elt;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
214 elt = Fcar (intail);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
215 if (CONSP (elt))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
216 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
217 Lisp_Object presflag, carelt;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
218 carelt = Fcar (elt);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
219 /* If it is (if X Y), look at Y. */
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
220 if (EQ (carelt, Qif)
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
221 && EQ (Fnthcdr (make_number (3), elt), Qnil))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
222 elt = Fnth (make_number (2), elt);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
223 /* If it is (when ... Y), look at Y. */
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
224 else if (EQ (carelt, Qwhen))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
225 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
226 while (CONSP (XCDR (elt)))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
227 elt = XCDR (elt);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
228 elt = Fcar (elt);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
229 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
230
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
231 /* If the function call we're looking at
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
232 is a special preserved one, copy the
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
233 whole expression for this argument. */
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
234 if (CONSP (elt))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
235 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
236 presflag = Fmemq (Fcar (elt), preserved_fns);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
237 if (!NILP (presflag))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
238 Fsetcar (valtail, Fcar (intail));
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
239 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
240 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
241 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
242 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
243 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
244 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
245
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
246 DEFUN ("call-interactively", Fcall_interactively, Scall_interactively, 1, 3, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
247 doc: /* Call FUNCTION, reading args according to its interactive calling specs.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
248 Return the value FUNCTION returns.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
249 The function contains a specification of how to do the argument reading.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
250 In the case of user-defined functions, this is specified by placing a call
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
251 to the function `interactive' at the top level of the function body.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
252 See `interactive'.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
253
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
254 Optional second arg RECORD-FLAG non-nil
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
255 means unconditionally put this command in the command-history.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
256 Otherwise, this is done only if an arg is read using the minibuffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
257 Optional third arg KEYS, if given, specifies the sequence of events to
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
258 supply if the command inquires which events were used to invoke it. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
259 (function, record_flag, keys)
14062
16a05061fee3 (Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents: 13843
diff changeset
260 Lisp_Object function, record_flag, keys;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
261 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
262 Lisp_Object *args, *visargs;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
263 unsigned char **argstrings;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
264 Lisp_Object fun;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
265 Lisp_Object funcar;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
266 Lisp_Object specs;
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
267 Lisp_Object filter_specs;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
268 Lisp_Object teml;
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
269 Lisp_Object enable;
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 46006
diff changeset
270 int speccount = SPECPDL_INDEX ();
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
271
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
272 /* 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
273 the 'e' interactive code. */
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
274 int next_event;
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
275
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
276 Lisp_Object prefix_arg;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
277 unsigned char *string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
278 unsigned char *tem;
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
279
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
280 /* If varies[i] > 0, the i'th argument shouldn't just have its value
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
281 in this call quoted in the command history. It should be
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
282 recorded as a call to the function named callint_argfuns[varies[i]]. */
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
283 int *varies;
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
284
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
285 register int i, j;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
286 int count, foo;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
287 char prompt1[100];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
288 char *tem1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
289 int arg_from_tty = 0;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
290 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
291 int key_count;
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
292 int record_then_fail = 0;
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
293
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
294 if (NILP (keys))
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
295 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
296 else
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
297 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40643
diff changeset
298 CHECK_VECTOR (keys);
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
299 key_count = XVECTOR (keys)->size;
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
300 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
301
732
a8d94735277e *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
302 /* 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
303 prefix_arg = Vcurrent_prefix_arg;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
304
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
305 retry:
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
306
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
307 if (SYMBOLP (function))
1115
eb7f1ab33a9d * callint.c (Fcall_interactively): Remove the 'K' interactive
Jim Blandy <jimb@redhat.com>
parents: 1084
diff changeset
308 enable = Fget (function, Qenable_recursive_minibuffers);
34799
c04a8de55245 (Fcall_interactively): Prevent a compiler warning.
Gerd Moellmann <gerd@gnu.org>
parents: 31336
diff changeset
309 else
c04a8de55245 (Fcall_interactively): Prevent a compiler warning.
Gerd Moellmann <gerd@gnu.org>
parents: 31336
diff changeset
310 enable = Qnil;
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
311
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 644
diff changeset
312 fun = indirect_function (function);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
313
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
314 specs = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
315 string = 0;
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
316 /* The idea of FILTER_SPECS is to provide away to
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
317 specify how to represent the arguments in command history.
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
318 The feature is not fully implemented. */
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
319 filter_specs = Qnil;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
320
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
321 /* Decode the kind of function. Either handle it and return,
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
322 or go to `lose' if not interactive, or go to `retry'
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
323 to specify a different function, or set either STRING or SPECS. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
324
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
325 if (SUBRP (fun))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
326 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
327 string = (unsigned char *) XSUBR (fun)->prompt;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
328 if (!string)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
329 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
330 lose:
1926
952f2a18f83d * callint.c (Fcall_interactively): Pass the correct number of
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
331 function = wrong_type_argument (Qcommandp, function);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
332 goto retry;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
333 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
334 }
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
335 else if (COMPILEDP (fun))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
336 {
10345
9952a5ab70d1 Fix typo in last change.
Roland McGrath <roland@gnu.org>
parents: 10343
diff changeset
337 if ((XVECTOR (fun)->size & PSEUDOVECTOR_SIZE_MASK) <= COMPILED_INTERACTIVE)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
338 goto lose;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
339 specs = XVECTOR (fun)->contents[COMPILED_INTERACTIVE];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
340 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
341 else if (!CONSP (fun))
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
342 goto lose;
39813
638b60fd98d0 (Fcall_interactively): Remove unused code. Use XCAR/XCDR.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39697
diff changeset
343 else if (funcar = XCAR (fun), EQ (funcar, Qautoload))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
344 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
345 GCPRO2 (function, prefix_arg);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
346 do_autoload (fun, function);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
347 UNGCPRO;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
348 goto retry;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
349 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
350 else if (EQ (funcar, Qlambda))
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
351 {
39813
638b60fd98d0 (Fcall_interactively): Remove unused code. Use XCAR/XCDR.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39697
diff changeset
352 specs = Fassq (Qinteractive, Fcdr (XCDR (fun)));
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
353 if (NILP (specs))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
354 goto lose;
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
355 filter_specs = Fnth (make_number (1), specs);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
356 specs = Fcar (Fcdr (specs));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
357 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
358 else
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
359 goto lose;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
360
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
361 /* 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
362 if (STRINGP (specs))
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
363 {
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
364 /* Make a copy of string so that if a GC relocates specs,
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
365 `string' will still be valid. */
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
366 string = (unsigned char *) alloca (SBYTES (specs) + 1);
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
367 bcopy (SDATA (specs), string,
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
368 SBYTES (specs) + 1);
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
369 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
370 else if (string == 0)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
371 {
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
372 Lisp_Object input;
17876
6e27f660a0be (Fcall_interactively): Use num_input_events.
Richard M. Stallman <rms@gnu.org>
parents: 17806
diff changeset
373 i = num_input_events;
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
374 input = specs;
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
375 /* Compute the arg values using the user's expression. */
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
376 GCPRO2 (input, filter_specs);
13843
f5bd72a6fe48 (Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 13764
diff changeset
377 specs = Feval (specs);
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
378 UNGCPRO;
17876
6e27f660a0be (Fcall_interactively): Use num_input_events.
Richard M. Stallman <rms@gnu.org>
parents: 17806
diff changeset
379 if (i != num_input_events || !NILP (record_flag))
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
380 {
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
381 /* We should record this command on the command history. */
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
382 Lisp_Object values, car;
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
383 /* 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
384 and turn them into things we can eval. */
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
385 values = quotify_args (Fcopy_sequence (specs));
49932
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
386 fix_command (input, values);
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
387 Vcommand_history
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
388 = Fcons (Fcons (function, values), Vcommand_history);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
389
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
390 /* Don't keep command history around forever. */
44405
0ed69545b5f3 (Fcall_interactively): Use INTEGERP instead of
Gerd Moellmann <gerd@gnu.org>
parents: 43039
diff changeset
391 if (INTEGERP (Vhistory_length) && XINT (Vhistory_length) > 0)
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
392 {
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
393 teml = Fnthcdr (Vhistory_length, Vcommand_history);
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
394 if (CONSP (teml))
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39945
diff changeset
395 XSETCDR (teml, Qnil);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
396 }
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
397 }
11345
c4adea8f7543 (Fcall_interactively): Call single_kboard_state
Richard M. Stallman <rms@gnu.org>
parents: 11280
diff changeset
398 single_kboard_state ();
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
399 return apply1 (function, specs);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
400 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
401
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
402 /* Here if function specifies a string to control parsing the defaults */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
403
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
404 /* 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
405 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
406 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
407 break;
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
408
7912
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
409 /* 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
410 /* Note that `+' is reserved for user extensions. */
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
411 while (1)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
412 {
11280
5146fba1f75d (Fcall_interactively): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents: 11278
diff changeset
413 if (*string == '+')
11278
25b2219c415c (Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents: 11009
diff changeset
414 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
415 else if (*string == '*')
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
416 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
417 string++;
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
418 if (!NILP (current_buffer->read_only))
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
419 {
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
420 if (!NILP (record_flag))
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
421 {
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
422 unsigned char *p = string;
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
423 while (*p)
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
424 {
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
425 if (! (*p == 'r' || *p == 'p' || *p == 'P'
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
426 || *p == '\n'))
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
427 Fbarf_if_buffer_read_only ();
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
428 p++;
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
429 }
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
430 record_then_fail = 1;
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
431 }
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
432 else
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
433 Fbarf_if_buffer_read_only ();
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
434 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
435 }
7912
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
436 /* Ignore this for semi-compatibility with Lucid. */
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
437 else if (*string == '-')
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
438 string++;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
439 else if (*string == '@')
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
440 {
6494
00475922df29 (check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6271
diff changeset
441 Lisp_Object event;
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
442
48630
edd0dd275f1f (Fcall_interactively): Use next_event only if less
Andreas Schwab <schwab@suse.de>
parents: 48527
diff changeset
443 event = (next_event < key_count
edd0dd275f1f (Fcall_interactively): Use next_event only if less
Andreas Schwab <schwab@suse.de>
parents: 48527
diff changeset
444 ? XVECTOR (keys)->contents[next_event]
edd0dd275f1f (Fcall_interactively): Use next_event only if less
Andreas Schwab <schwab@suse.de>
parents: 48527
diff changeset
445 : Qnil);
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
446 if (EVENT_HAS_PARAMETERS (event)
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
447 && (event = XCDR (event), CONSP (event))
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
448 && (event = XCAR (event), CONSP (event))
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
449 && (event = XCAR (event), WINDOWP (event)))
6270
853b88dd9945 (Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents: 4696
diff changeset
450 {
6271
264f353c5b00 Fix typo in previous change.
Karl Heuer <kwzh@gnu.org>
parents: 6270
diff changeset
451 if (MINI_WINDOW_P (XWINDOW (event))
7912
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
452 && ! (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
453 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
454
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
455 /* 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
456 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
457 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
458
6270
853b88dd9945 (Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents: 4696
diff changeset
459 Fselect_window (event);
853b88dd9945 (Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents: 4696
diff changeset
460 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
461 string++;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
462 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
463 else break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
464 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
465
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
466 /* Count the number of arguments the interactive spec would have
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
467 us give to the function. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
468 tem = string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
469 for (j = 0; *tem; j++)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
470 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
471 /* 'r' specifications ("point and mark as 2 numeric args")
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
472 produce *two* arguments. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
473 if (*tem == 'r') j++;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
474 tem = (unsigned char *) index (tem, '\n');
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
475 if (tem)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
476 tem++;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
477 else
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
478 tem = (unsigned char *) "";
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
479 }
13843
f5bd72a6fe48 (Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 13764
diff changeset
480 count = j;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
481
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
482 args = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
483 visargs = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
484 argstrings = (unsigned char **) alloca ((count + 1) * sizeof (char *));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
485 varies = (int *) alloca ((count + 1) * sizeof (int));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
486
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
487 for (i = 0; i < (count + 1); i++)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
488 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
489 args[i] = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
490 visargs[i] = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
491 varies[i] = 0;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
492 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
493
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
494 GCPRO4 (prefix_arg, function, *args, *visargs);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
495 gcpro3.nvars = (count + 1);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
496 gcpro4.nvars = (count + 1);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
497
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
498 if (!NILP (enable))
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
499 specbind (Qenable_recursive_minibuffers, Qt);
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
500
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
501 tem = string;
13843
f5bd72a6fe48 (Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 13764
diff changeset
502 for (i = 1; *tem; i++)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
503 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
504 strncpy (prompt1, tem + 1, sizeof prompt1 - 1);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
505 prompt1[sizeof prompt1 - 1] = 0;
31225
7930c46bb365 (toplevel) [HAVE_STRING_H]: Include string.h.
Gerd Moellmann <gerd@gnu.org>
parents: 29371
diff changeset
506 tem1 = (char *) index (prompt1, '\n');
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
507 if (tem1) *tem1 = 0;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
508 /* Fill argstrings with a vector of C strings
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
509 corresponding to the Lisp strings in visargs. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
510 for (j = 1; j < i; j++)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
511 argstrings[j]
20552
1a0cb8cd5615 (Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents: 19759
diff changeset
512 = (EQ (visargs[j], Qnil)
1a0cb8cd5615 (Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents: 19759
diff changeset
513 ? (unsigned char *) ""
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
514 : SDATA (visargs[j]));
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
515
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
516 /* 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
517 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
518 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
519 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
520 while (1)
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
521 {
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
522 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
523 prompt1, (char *)0,
20552
1a0cb8cd5615 (Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents: 19759
diff changeset
524 j - 1, (char **) argstrings + 1);
46006
6d5d3dd50de6 (Fcall_interactively): When checking to see if doprnt hit
Miles Bader <miles@gnu.org>
parents: 45546
diff changeset
525 if (nchars < callint_message_size - 1)
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
526 break;
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
527 callint_message_size *= 2;
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
528 callint_message
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
529 = (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
530 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
531
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
532 switch (*tem)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
533 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
534 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
535 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
536 Vobarray, Qfboundp, Qt,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
537 Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
538 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
539 teml = visargs[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
540 args[i] = Fintern (teml, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
541 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
542
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
543 case 'b': /* Name of existing buffer */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
544 args[i] = Fcurrent_buffer ();
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
545 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
546 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
547 args[i] = Fread_buffer (build_string (callint_message), args[i], Qt);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
548 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
549
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
550 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
551 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
552 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
553 Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
554 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
555
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
556 case 'c': /* Character */
23934
93f40b344070 (Fcall_interactively) <'C'>: Give Fread_char Qnil
Kenichi Handa <handa@m17n.org>
parents: 23301
diff changeset
557 args[i] = Fread_char (build_string (callint_message), Qnil);
13754
8310d6085087 (Fcall_interactively): Don't log prompt strings.
Karl Heuer <kwzh@gnu.org>
parents: 13664
diff changeset
558 message1_nolog ((char *) 0);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
559 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
560 teml = args[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
561 visargs[i] = Fchar_to_string (teml);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
562 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
563
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
564 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
565 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
566 Vobarray, Qcommandp,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
567 Qt, Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
568 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
569 teml = visargs[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
570 args[i] = Fintern (teml, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
571 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
572
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
573 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
574 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
575 args[i] = point_marker;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
576 /* visargs[i] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
577 varies[i] = 1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
578 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
579
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
580 case 'D': /* Directory name. */
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
581 args[i] = Fread_file_name (build_string (callint_message), Qnil,
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
582 current_buffer->directory, Qlambda, Qnil,
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
583 Qfile_directory_p);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
584 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
585
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
586 case 'f': /* Existing file name. */
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
587 args[i] = Fread_file_name (build_string (callint_message),
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
588 Qnil, Qnil, Qlambda, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
589 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
590
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
591 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
592 args[i] = Fread_file_name (build_string (callint_message),
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
593 Qnil, Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
594 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
595
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
596 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
597 varies[i] = -1;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
598 break;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
599
10540
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
600 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
601 {
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 46006
diff changeset
602 int speccount1 = SPECPDL_INDEX ();
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
603 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
604 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
605 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
606 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
607 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
608 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
609
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
610 /* 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
611 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
612 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
613 if (CONSP (teml))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
614 teml = XCAR (teml);
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
615 if (SYMBOLP (teml))
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
616 {
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
617 Lisp_Object tem2;
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
618
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
619 teml = Fget (teml, intern ("event-symbol-elements"));
24911
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
620 /* Ignore first element, which is the base key. */
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
621 tem2 = Fmemq (intern ("down"), Fcdr (teml));
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
622 if (! NILP (tem2))
23064
32a7b4dc421e (Fcall_interactively): Pass new args to Fread_event
Richard M. Stallman <rms@gnu.org>
parents: 22932
diff changeset
623 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
624 }
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
625 }
10540
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
626 break;
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
627
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
628 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
629 {
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 46006
diff changeset
630 int speccount1 = SPECPDL_INDEX ();
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
631 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
632 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
633 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
634 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
635 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
636 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
637
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
638 /* 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
639 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
640 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
641 if (CONSP (teml))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
642 teml = XCAR (teml);
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
643 if (SYMBOLP (teml))
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
644 {
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
645 Lisp_Object tem2;
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
646
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
647 teml = Fget (teml, intern ("event-symbol-elements"));
24911
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
648 /* Ignore first element, which is the base key. */
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
649 tem2 = Fmemq (intern ("down"), Fcdr (teml));
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
650 if (! NILP (tem2))
23064
32a7b4dc421e (Fcall_interactively): Pass new args to Fread_event
Richard M. Stallman <rms@gnu.org>
parents: 22932
diff changeset
651 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
652 }
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
653 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
654 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
655
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
656 case 'e': /* The invoking event. */
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
657 if (next_event >= key_count)
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
658 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
659 (SYMBOLP (function)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
660 ? (char *) SDATA (SYMBOL_NAME (function))
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
661 : "command"));
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
662 args[i] = XVECTOR (keys)->contents[next_event++];
732
a8d94735277e *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
663 varies[i] = -1;
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
664
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
665 /* Find the next parameterized event. */
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
666 while (next_event < key_count
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
667 && ! (EVENT_HAS_PARAMETERS
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
668 (XVECTOR (keys)->contents[next_event])))
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
669 next_event++;
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
670
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
671 break;
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
672
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
673 case 'm': /* Value of mark. Does not do I/O. */
43039
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
674 check_mark (0);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
675 /* visargs[i] = Qnil; */
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
676 args[i] = current_buffer->mark;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
677 varies[i] = 2;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
678 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
679
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
680 case 'M': /* String read via minibuffer with
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
681 inheriting the current input method. */
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
682 args[i] = Fread_string (build_string (callint_message),
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
683 Qnil, Qnil, Qnil, Qt);
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
684 break;
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
685
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
686 case 'N': /* Prefix arg, else number from minibuffer */
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
687 if (!NILP (prefix_arg))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
688 goto have_prefix_arg;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
689 case 'n': /* Read number from minibuffer. */
15961
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
690 {
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
691 int first = 1;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
692 do
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
693 {
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
694 Lisp_Object tem;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
695 if (! first)
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
696 {
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
697 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
698 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
699 }
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
700 first = 0;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
701
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
702 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
703 Qnil, Qnil, Qnil, Qnil, Qnil,
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
704 Qnil);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
705 if (! STRINGP (tem) || SCHARS (tem) == 0)
15961
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
706 args[i] = Qnil;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
707 else
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
708 args[i] = Fread (tem);
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
709 }
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
710 while (! NUMBERP (args[i]));
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
711 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
712 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
713 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
714
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
715 case 'P': /* Prefix arg in raw form. Does no I/O. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
716 args[i] = prefix_arg;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
717 /* visargs[i] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
718 varies[i] = -1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
719 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
720
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
721 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
722 have_prefix_arg:
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
723 args[i] = Fprefix_numeric_value (prefix_arg);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
724 /* visargs[i] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
725 varies[i] = -1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
726 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
727
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
728 case 'r': /* Region, point and mark as 2 args. */
43039
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
729 check_mark (1);
20552
1a0cb8cd5615 (Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents: 19759
diff changeset
730 set_marker_both (point_marker, Qnil, PT, PT_BYTE);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
731 /* visargs[i+1] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
732 foo = marker_position (current_buffer->mark);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
733 /* visargs[i] = Qnil; */
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15961
diff changeset
734 args[i] = PT < foo ? point_marker : current_buffer->mark;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
735 varies[i] = 3;
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15961
diff changeset
736 args[++i] = PT > foo ? point_marker : current_buffer->mark;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
737 varies[i] = 4;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
738 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
739
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
740 case 's': /* String read via minibuffer without
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
741 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
742 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
743 Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
744 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
745
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
746 case 'S': /* Any symbol. */
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
747 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
748 Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
749 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
750 teml = visargs[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
751 args[i] = Fintern (teml, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
752 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
753
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
754 case 'v': /* Variable name: symbol that is
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
755 user-variable-p. */
17736
8b30ef18c480 (Fcall_interactively): Pass new arg to
Richard M. Stallman <rms@gnu.org>
parents: 17024
diff changeset
756 args[i] = Fread_variable (build_string (callint_message), Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
757 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
758 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
759
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
760 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
761 args[i] = Fread_minibuffer (build_string (callint_message), Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
762 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
763 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
764
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
765 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
766 args[i] = Feval_minibuffer (build_string (callint_message), Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
767 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
768 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
769
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
770 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
771 argument if no prefix */
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
772 if (NILP (prefix_arg))
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
773 {
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
774 args[i] = Qnil;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
775 varies[i] = -1;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
776 }
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48630
diff changeset
777 else
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
778 {
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
779 args[i]
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
780 = 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
781 visargs[i] = last_minibuf_string;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
782 }
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
783 break;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
784
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
785 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
786 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
787 visargs[i] = last_minibuf_string;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
788 break;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
789
11278
25b2219c415c (Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents: 11009
diff changeset
790 /* 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
791 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
792 case '+':
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
793 default:
11278
25b2219c415c (Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents: 11009
diff changeset
794 error ("Invalid control letter `%c' (%03o) in interactive calling string",
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
795 *tem, *tem);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
796 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
797
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
798 if (varies[i] == 0)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
799 arg_from_tty = 1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
800
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
801 if (NILP (visargs[i]) && STRINGP (args[i]))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
802 visargs[i] = args[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
803
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
804 tem = (unsigned char *) index (tem, '\n');
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
805 if (tem) tem++;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
806 else tem = (unsigned char *) "";
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
807 }
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
808 unbind_to (speccount, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
809
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
810 QUIT;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
811
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
812 args[0] = function;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
813
14062
16a05061fee3 (Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents: 13843
diff changeset
814 if (arg_from_tty || !NILP (record_flag))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
815 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
816 visargs[0] = function;
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
817 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
818 {
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
819 if (varies[i] > 0)
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
820 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
821 else
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
822 visargs[i] = quotify_arg (args[i]);
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
823 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
824 Vcommand_history = Fcons (Flist (count + 1, visargs),
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
825 Vcommand_history);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
826 /* Don't keep command history around forever. */
44405
0ed69545b5f3 (Fcall_interactively): Use INTEGERP instead of
Gerd Moellmann <gerd@gnu.org>
parents: 43039
diff changeset
827 if (INTEGERP (Vhistory_length) && XINT (Vhistory_length) > 0)
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
828 {
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
829 teml = Fnthcdr (Vhistory_length, Vcommand_history);
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
830 if (CONSP (teml))
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39945
diff changeset
831 XSETCDR (teml, Qnil);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
832 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
833 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
834
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
835 /* 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
836 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
837 for (i = 1; i <= count; i++)
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
838 if (varies[i] >= 1 && varies[i] <= 4)
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
839 XSETINT (args[i], marker_position (args[i]));
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
840
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
841 if (record_then_fail)
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
842 Fbarf_if_buffer_read_only ();
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
843
11345
c4adea8f7543 (Fcall_interactively): Call single_kboard_state
Richard M. Stallman <rms@gnu.org>
parents: 11280
diff changeset
844 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
845
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
846 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
847 Lisp_Object val;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
848 specbind (Qcommand_debug_status, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
849
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
850 val = Ffuncall (count + 1, args);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
851 UNGCPRO;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
852 return unbind_to (speccount, val);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
853 }
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48630
diff changeset
854 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
855
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
856 DEFUN ("prefix-numeric-value", Fprefix_numeric_value, Sprefix_numeric_value,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
857 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
858 doc: /* Return numeric meaning of raw prefix argument RAW.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
859 A raw prefix argument is what you get from `(interactive "P")'.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
860 Its numeric meaning is what you would get from `(interactive "p")'. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
861 (raw)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
862 Lisp_Object raw;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
863 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
864 Lisp_Object val;
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48630
diff changeset
865
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
866 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
867 XSETFASTINT (val, 1);
819
5bbabfcef929 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 732
diff changeset
868 else if (EQ (raw, Qminus))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
869 XSETINT (val, -1);
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
870 else if (CONSP (raw) && INTEGERP (XCAR (raw)))
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
871 XSETINT (val, XINT (XCAR (raw)));
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
872 else if (INTEGERP (raw))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
873 val = raw;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
874 else
9298
6e3aea54fc01 (Fcall_interactively, Fprefix_numeric_value): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents: 9290
diff changeset
875 XSETFASTINT (val, 1);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
876
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
877 return val;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
878 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
879
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21244
diff changeset
880 void
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
881 syms_of_callint ()
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
882 {
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
883 point_marker = Fmake_marker ();
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
884 staticpro (&point_marker);
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
885
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
886 preserved_fns = Fcons (intern ("region-beginning"),
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
887 Fcons (intern ("region-end"),
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
888 Fcons (intern ("point"),
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
889 Fcons (intern ("mark"), Qnil))));
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
890 staticpro (&preserved_fns);
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
891
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
892 Qlist = intern ("list");
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
893 staticpro (&Qlist);
13447
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
894 Qlet = intern ("let");
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
895 staticpro (&Qlet);
49932
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
896 Qif = intern ("if");
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
897 staticpro (&Qif);
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
898 Qwhen = intern ("when");
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
899 staticpro (&Qwhen);
13447
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
900 Qletx = intern ("let*");
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
901 staticpro (&Qletx);
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
902 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
903 staticpro (&Qsave_excursion);
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
904 Qprogn = intern ("progn");
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
905 staticpro (&Qprogn);
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
906
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
907 Qminus = intern ("-");
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
908 staticpro (&Qminus);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
909
9100
7dacd83e0fe0 (Qplus): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8819
diff changeset
910 Qplus = intern ("+");
7dacd83e0fe0 (Qplus): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8819
diff changeset
911 staticpro (&Qplus);
7dacd83e0fe0 (Qplus): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8819
diff changeset
912
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
913 Qcall_interactively = intern ("call-interactively");
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
914 staticpro (&Qcall_interactively);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
915
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
916 Qcommand_debug_status = intern ("command-debug-status");
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
917 staticpro (&Qcommand_debug_status);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
918
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
919 Qenable_recursive_minibuffers = intern ("enable-recursive-minibuffers");
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
920 staticpro (&Qenable_recursive_minibuffers);
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
921
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
922 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
923 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
924
13142
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
925 callint_message_size = 100;
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
926 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
927
297a0e21501a (callint_message, callint_message_size): New vars.
Richard M. Stallman <rms@gnu.org>
parents: 12582
diff changeset
928
12117
3fa5b6e7ad4b (current_prefix_partial): Deleted.
Karl Heuer <kwzh@gnu.org>
parents: 11911
diff changeset
929 DEFVAR_KBOARD ("prefix-arg", Vprefix_arg,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
930 doc: /* The value of the prefix argument for the next editing command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
931 It may be a number, or the symbol `-' for just a minus sign as arg,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
932 or a list whose car is a number for just one or more C-u's
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
933 or nil if no argument has been specified.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
934
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
935 You cannot examine this variable to find the argument for this command
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
936 since it has been set to nil by the time you can look.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
937 Instead, you should use the variable `current-prefix-arg', although
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
938 normally commands can get this prefix argument with (interactive "P"). */);
10857
2b9faff73319 (Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents: 10846
diff changeset
939
22383
9ef0fe84c5ed (syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 22244
diff changeset
940 DEFVAR_KBOARD ("last-prefix-arg", Vlast_prefix_arg,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
941 doc: /* The value of the prefix argument for the previous editing command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
942 See `prefix-arg' for the meaning of the value. */);
22383
9ef0fe84c5ed (syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 22244
diff changeset
943
10857
2b9faff73319 (Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents: 10846
diff changeset
944 DEFVAR_LISP ("current-prefix-arg", &Vcurrent_prefix_arg,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
945 doc: /* The value of the prefix argument for this editing command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
946 It may be a number, or the symbol `-' for just a minus sign as arg,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
947 or a list whose car is a number for just one or more C-u's
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
948 or nil if no argument has been specified.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
949 This is what `(interactive \"P\")' returns. */);
10857
2b9faff73319 (Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents: 10846
diff changeset
950 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
951
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
952 DEFVAR_LISP ("command-history", &Vcommand_history,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
953 doc: /* List of recent commands that read arguments from terminal.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
954 Each command is represented as a form to evaluate. */);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
955 Vcommand_history = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
956
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
957 DEFVAR_LISP ("command-debug-status", &Vcommand_debug_status,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
958 doc: /* Debugging status of current interactive command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
959 Bound each time `call-interactively' is called;
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
960 may be set by the debugger as a reminder for itself. */);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
961 Vcommand_debug_status = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
962
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
963 DEFVAR_LISP ("mark-even-if-inactive", &Vmark_even_if_inactive,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
964 doc: /* *Non-nil means you can use the mark even when inactive.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
965 This option makes a difference in Transient Mark mode.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
966 When the option is non-nil, deactivation of the mark
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
967 turns off region highlighting, but commands that use the mark
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
968 behave as if the mark were still active. */);
3975
718280a1ba74 (Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 2048
diff changeset
969 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
970
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
971 DEFVAR_LISP ("mouse-leave-buffer-hook", &Vmouse_leave_buffer_hook,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
972 doc: /* Hook to run when about to switch windows with a mouse command.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
973 Its purpose is to give temporary modes such as Isearch mode
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
974 a way to turn themselves off when a mouse command switches windows. */);
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
975 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
976
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
977 defsubr (&Sinteractive);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
978 defsubr (&Scall_interactively);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
979 defsubr (&Sprefix_numeric_value);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
980 }