annotate src/callint.c @ 95767:efe53e2a05b0

Correct copyright years to reflect the original newsticker.el from which most of this code was extracted, not the year it was moved into this file. Header formatting fix.
author Glenn Morris <rgm@gnu.org>
date Tue, 10 Jun 2008 03:21:37 +0000
parents 8971ddf55736
children 8233f3e2beb4
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.
75227
e90d04cd455a Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents: 74912
diff changeset
2 Copyright (C) 1985, 1986, 1993, 1994, 1995, 1997, 2000, 2001, 2002,
79759
fc2bcd2a8aad Add 2008 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 79601
diff changeset
3 2003, 2004, 2005, 2006, 2007, 2008
fc2bcd2a8aad Add 2008 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 79601
diff changeset
4 Free Software Foundation, Inc.
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
5
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
6 This file is part of GNU Emacs.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
7
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93607
diff changeset
8 GNU Emacs is free software: you can redistribute it and/or modify
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
9 it under the terms of the GNU General Public License as published by
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93607
diff changeset
10 the Free Software Foundation, either version 3 of the License, or
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93607
diff changeset
11 (at your option) any later version.
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
12
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
13 GNU Emacs is distributed in the hope that it will be useful,
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
16 GNU General Public License for more details.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
17
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93607
diff changeset
19 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
20
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
21
4696
1fc792473491 Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents: 4046
diff changeset
22 #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
23
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
24 #include "lisp.h"
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
25 #include "buffer.h"
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
26 #include "commands.h"
516
ccadad491483 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 485
diff changeset
27 #include "keyboard.h"
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
28 #include "window.h"
39697
0b986bb45526 Include keymap.h.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 34799
diff changeset
29 #include "keymap.h"
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
30
31336
3ecef4a7b3cd Remove includes of
Gerd Moellmann <gerd@gnu.org>
parents: 31225
diff changeset
31 #ifdef HAVE_INDEX
3ecef4a7b3cd Remove includes of
Gerd Moellmann <gerd@gnu.org>
parents: 31225
diff changeset
32 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
33 #endif
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
34
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
35 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
36 extern Lisp_Object Qfile_directory_p;
93607
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
37 extern Lisp_Object Qonly;
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;
52374
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
44 extern Lisp_Object Vthis_original_command, real_this_command;
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
45
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
46 Lisp_Object Vcommand_debug_status, Qcommand_debug_status;
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
47 Lisp_Object Qenable_recursive_minibuffers;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
48
3975
718280a1ba74 (Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 2048
diff changeset
49 /* 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
50 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
51 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
52
93542
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
53 Lisp_Object Vshift_select_mode, Qhandle_shift_selection;
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
54
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
55 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
56
49932
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
57 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
58 static Lisp_Object preserved_fns;
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
59
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
60 /* 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
61 static Lisp_Object point_marker;
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
62
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
63 /* String for the prompt text used in Fcall_interactively. */
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
64 static Lisp_Object callint_message;
74912
4c1d868b634b (Finteractive): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 73441
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.
60681
046708b92d49 (Finteractive): Document G option.
Richard M. Stallman <rms@gnu.org>
parents: 58380
diff changeset
100 G -- Possibly nonexistent file name, defaulting to just directory name.
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
101 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
102 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
103 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
104 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
105 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
106 n -- Number read using minibuffer.
74912
4c1d868b634b (Finteractive): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 73441
diff changeset
107 N -- Numeric prefix arg, or if none, do like code `n'.
40103
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 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
109 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
110 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
111 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
112 S -- Any symbol.
57707
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
113 U -- Mouse up event discarded by a previous k or K argument.
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
114 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
115 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
116 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
117 z -- Coding system.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
118 Z -- Coding system, nil if no prefix arg.
93542
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
119
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
120 In addition, if the string begins with `*', an error is signaled if
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
121 the buffer is read-only.
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
122 If the string begins with `@', Emacs searches the key sequence which
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
123 invoked the command for its first mouse click (or any other event
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
124 which specifies a window).
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
125 If the string begins with `^' and `shift-select-mode' is non-nil,
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
126 Emacs first calls the function `handle-shift-select'.
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
127 You may use `@', `*', and `^' together. They are processed in the
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
128 order that they appear, before reading any arguments.
40643
184e0d756547 (Finteractive): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 40103
diff changeset
129 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
130 (args)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
131 Lisp_Object args;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
132 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
133 return Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
134 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
135
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
136 /* Quotify EXP: if EXP is constant, return it.
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
137 If EXP is not constant, return (quote EXP). */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
138 Lisp_Object
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
139 quotify_arg (exp)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
140 register Lisp_Object exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
141 {
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
142 if (!INTEGERP (exp) && !STRINGP (exp)
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
143 && !NILP (exp) && !EQ (exp, Qt))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
144 return Fcons (Qquote, Fcons (exp, Qnil));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
145
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
146 return exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
147 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
148
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
149 /* Modify EXP by quotifying each element (except the first). */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
150 Lisp_Object
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
151 quotify_args (exp)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
152 Lisp_Object exp;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
153 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
154 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
155 Lisp_Object next;
d39ec0a27081 more XCAR/XCDR/XFLOAT_DATA uses, to help isolete lisp engine
Ken Raeburn <raeburn@raeburn.org>
parents: 25645
diff changeset
156 for (tail = exp; CONSP (tail); tail = next)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
157 {
26164
d39ec0a27081 more XCAR/XCDR/XFLOAT_DATA uses, to help isolete lisp engine
Ken Raeburn <raeburn@raeburn.org>
parents: 25645
diff changeset
158 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
159 XSETCAR (tail, quotify_arg (XCAR (tail)));
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
160 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
161 return exp;
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
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
164 char *callint_argfuns[]
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
165 = {"", "point", "mark", "region-beginning", "region-end"};
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
166
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
167 static void
43039
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
168 check_mark (for_region)
531bd3a9e67a (check_mark): New arg to specify clearer error message.
Richard M. Stallman <rms@gnu.org>
parents: 42272
diff changeset
169 int for_region;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
170 {
6494
00475922df29 (check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6271
diff changeset
171 Lisp_Object tem;
00475922df29 (check_mark, Fcall_interactively): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6271
diff changeset
172 tem = Fmarker_buffer (current_buffer->mark);
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
173 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
174 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
175 : "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
176 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
177 && NILP (current_buffer->mark_active))
71969
34c5e405ed37 (check_mark): Use xsignal0.
Kim F. Storm <storm@cua.dk>
parents: 71826
diff changeset
178 xsignal0 (Qmark_inactive);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
179 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
180
50469
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
181 /* 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
182 `list', look for elements that were computed with
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
183 (region-beginning) or (region-end), and put those expressions into
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
184 VALUES instead of the present values.
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
185
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
186 This function doesn't return a value because it modifies elements
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
187 of VALUES to do its job. */
0bdc2fd19631 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 49953
diff changeset
188
49953
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
189 static void
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
190 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
191 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
192 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
193 if (CONSP (input))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
194 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
195 Lisp_Object car;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
196
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
197 car = XCAR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
198 /* 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
199 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
200 || 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
201 || EQ (car, Qprogn))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
202 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
203 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
204 input = XCDR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
205 input = XCAR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
206 if (!CONSP (input))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
207 break;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
208 car = XCAR (input);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
209 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
210 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
211 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
212 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
213 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
214 CONSP (valtail);
54891
6258852d3607 (fix_command): Use XDCR.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54641
diff changeset
215 intail = Fcdr (intail), valtail = XCDR (valtail))
49953
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 elt;
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
218 elt = Fcar (intail);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
219 if (CONSP (elt))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
220 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
221 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
222 carelt = Fcar (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 (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
224 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
225 && 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
226 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
227 /* 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
228 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
229 {
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
230 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
231 elt = XCDR (elt);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
232 elt = Fcar (elt);
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
233 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
234
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
235 /* 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
236 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
237 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
238 if (CONSP (elt))
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 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
241 if (!NILP (presflag))
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
242 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
243 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
244 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
245 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
246 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
247 }
c57ce680648d (fix_command): Declare as static void and move before Fcall_interactively.
Juanma Barranquero <lekktu@gmail.com>
parents: 49932
diff changeset
248 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
249
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
250 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
251 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
252 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
253 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
254 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
255 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
256 See `interactive'.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
257
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
258 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
259 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
260 Otherwise, this is done only if an arg is read using the minibuffer.
73120
6d481bdb9779 * callint.c (Fcall_interactively): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 72135
diff changeset
261
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
262 Optional third arg KEYS, if given, specifies the sequence of events to
73120
6d481bdb9779 * callint.c (Fcall_interactively): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 72135
diff changeset
263 supply, as a vector, if the command inquires which events were used to
6d481bdb9779 * callint.c (Fcall_interactively): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 72135
diff changeset
264 invoke it. If KEYS is omitted or nil, the return value of
6d481bdb9779 * callint.c (Fcall_interactively): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 72135
diff changeset
265 `this-command-keys-vector' is used. */)
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
266 (function, record_flag, keys)
14062
16a05061fee3 (Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents: 13843
diff changeset
267 Lisp_Object function, record_flag, keys;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
268 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
269 Lisp_Object *args, *visargs;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
270 Lisp_Object specs;
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
271 Lisp_Object filter_specs;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
272 Lisp_Object teml;
57707
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
273 Lisp_Object up_event;
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
274 Lisp_Object enable;
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 46006
diff changeset
275 int speccount = SPECPDL_INDEX ();
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
276
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
277 /* 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
278 the 'e' interactive code. */
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
279 int next_event;
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
280
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
281 Lisp_Object prefix_arg;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
282 unsigned char *string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
283 unsigned char *tem;
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
284
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
285 /* 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
286 in this call quoted in the command history. It should be
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
287 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
288 int *varies;
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
289
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
290 register int i, j;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
291 int count, foo;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
292 char prompt1[100];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
293 char *tem1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
294 int arg_from_tty = 0;
57707
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
295 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4, gcpro5;
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
296 int key_count;
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
297 int record_then_fail = 0;
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
298
52374
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
299 Lisp_Object save_this_command, save_last_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
300 Lisp_Object save_this_original_command, save_real_this_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
301
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
302 save_this_command = Vthis_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
303 save_this_original_command = Vthis_original_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
304 save_real_this_command = real_this_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
305 save_last_command = current_kboard->Vlast_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
306
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
307 if (NILP (keys))
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
308 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
309 else
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
310 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40643
diff changeset
311 CHECK_VECTOR (keys);
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
312 key_count = XVECTOR (keys)->size;
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
313 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
314
732
a8d94735277e *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
315 /* 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
316 prefix_arg = Vcurrent_prefix_arg;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
317
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
318 if (SYMBOLP (function))
1115
eb7f1ab33a9d * callint.c (Fcall_interactively): Remove the 'K' interactive
Jim Blandy <jimb@redhat.com>
parents: 1084
diff changeset
319 enable = Fget (function, Qenable_recursive_minibuffers);
34799
c04a8de55245 (Fcall_interactively): Prevent a compiler warning.
Gerd Moellmann <gerd@gnu.org>
parents: 31336
diff changeset
320 else
c04a8de55245 (Fcall_interactively): Prevent a compiler warning.
Gerd Moellmann <gerd@gnu.org>
parents: 31336
diff changeset
321 enable = Qnil;
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
322
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
323 specs = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
324 string = 0;
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
325 /* 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
326 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
327 The feature is not fully implemented. */
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
328 filter_specs = Qnil;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
329
57707
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
330 /* If k or K discard an up-event, save it here so it can be retrieved with U */
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
331 up_event = Qnil;
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
332
84432
b51e2df52bfb (Fcall_interactively): Comment fixes.
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 84426
diff changeset
333 /* Set SPECS to the interactive form, or barf if not interactive. */
84426
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
334 {
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
335 Lisp_Object form;
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
336 GCPRO2 (function, prefix_arg);
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
337 form = Finteractive_form (function);
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
338 UNGCPRO;
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
339 if (CONSP (form))
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
340 specs = filter_specs = Fcar (XCDR (form));
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
341 else
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
342 wrong_type_argument (Qcommandp, function);
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
343 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
344
84432
b51e2df52bfb (Fcall_interactively): Comment fixes.
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 84426
diff changeset
345 /* If SPECS is set to a string, use it as an interactive prompt. */
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
346 if (STRINGP (specs))
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
347 {
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
348 /* 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
349 `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
350 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
351 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
352 SBYTES (specs) + 1);
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 516
diff changeset
353 }
84426
74dfb3b7d8f2 (Fcall_interactively): Use Finteractive_form also for subrs
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 83648
diff changeset
354 else
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
355 {
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
356 Lisp_Object input;
17876
6e27f660a0be (Fcall_interactively): Use num_input_events.
Richard M. Stallman <rms@gnu.org>
parents: 17806
diff changeset
357 i = num_input_events;
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
358 input = specs;
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
359 /* 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
360 GCPRO2 (input, filter_specs);
13843
f5bd72a6fe48 (Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 13764
diff changeset
361 specs = Feval (specs);
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
362 UNGCPRO;
17876
6e27f660a0be (Fcall_interactively): Use num_input_events.
Richard M. Stallman <rms@gnu.org>
parents: 17806
diff changeset
363 if (i != num_input_events || !NILP (record_flag))
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
364 {
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
365 /* We should record this command on the command history. */
51048
7ac9c3bea5ea (Fselect_window): Add optional arg `norecord'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50469
diff changeset
366 Lisp_Object values;
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
367 /* 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
368 and turn them into things we can eval. */
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
369 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
370 fix_command (input, values);
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
371 Vcommand_history
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
372 = Fcons (Fcons (function, values), Vcommand_history);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
373
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
374 /* Don't keep command history around forever. */
44405
0ed69545b5f3 (Fcall_interactively): Use INTEGERP instead of
Gerd Moellmann <gerd@gnu.org>
parents: 43039
diff changeset
375 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
376 {
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
377 teml = Fnthcdr (Vhistory_length, Vcommand_history);
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
378 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
379 XSETCDR (teml, Qnil);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
380 }
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
381 }
52374
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
382
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
383 Vthis_command = save_this_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
384 Vthis_original_command = save_this_original_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
385 real_this_command= save_real_this_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
386 current_kboard->Vlast_command = save_last_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
387
83374
0b75ace4f7ad Fix crash after y-or-n-p prompt triggered by emacsclient. (Reported by Han Boetes, analysis by Kalle Olavi Niemitalo.)
Karoly Lorentey <lorentey@elte.hu>
parents: 64770
diff changeset
388 temporarily_switch_to_single_kboard (NULL);
0b75ace4f7ad Fix crash after y-or-n-p prompt triggered by emacsclient. (Reported by Han Boetes, analysis by Kalle Olavi Niemitalo.)
Karoly Lorentey <lorentey@elte.hu>
parents: 64770
diff changeset
389 return unbind_to (speccount, apply1 (function, specs));
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
390 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
391
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
392 /* Here if function specifies a string to control parsing the defaults */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
393
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
394 /* 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
395 for (next_event = 0; next_event < key_count; next_event++)
91949
d3395bc69ea8 (Fcall_interactively): Use AREF.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91911
diff changeset
396 if (EVENT_HAS_PARAMETERS (AREF (keys, next_event)))
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
397 break;
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
398
7912
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
399 /* 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
400 /* Note that `+' is reserved for user extensions. */
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
401 while (1)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
402 {
11280
5146fba1f75d (Fcall_interactively): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents: 11278
diff changeset
403 if (*string == '+')
11278
25b2219c415c (Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents: 11009
diff changeset
404 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
405 else if (*string == '*')
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
406 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
407 string++;
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
408 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
409 {
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
410 if (!NILP (record_flag))
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
411 {
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
412 unsigned char *p = string;
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
413 while (*p)
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
414 {
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
415 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
416 || *p == '\n'))
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
417 Fbarf_if_buffer_read_only ();
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
418 p++;
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 record_then_fail = 1;
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 else
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
423 Fbarf_if_buffer_read_only ();
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
424 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
425 }
7912
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
426 /* Ignore this for semi-compatibility with Lucid. */
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
427 else if (*string == '-')
f87185e63bbc (Fcall_interactively): Ignore `-' in string.
Richard M. Stallman <rms@gnu.org>
parents: 7307
diff changeset
428 string++;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
429 else if (*string == '@')
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
430 {
57998
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
431 Lisp_Object event, tem;
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
432
48630
edd0dd275f1f (Fcall_interactively): Use next_event only if less
Andreas Schwab <schwab@suse.de>
parents: 48527
diff changeset
433 event = (next_event < key_count
91949
d3395bc69ea8 (Fcall_interactively): Use AREF.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91911
diff changeset
434 ? AREF (keys, next_event)
48630
edd0dd275f1f (Fcall_interactively): Use next_event only if less
Andreas Schwab <schwab@suse.de>
parents: 48527
diff changeset
435 : Qnil);
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
436 if (EVENT_HAS_PARAMETERS (event)
57998
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
437 && (tem = XCDR (event), CONSP (tem))
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
438 && (tem = XCAR (tem), CONSP (tem))
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
439 && (tem = XCAR (tem), WINDOWP (tem)))
6270
853b88dd9945 (Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents: 4696
diff changeset
440 {
57998
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
441 if (MINI_WINDOW_P (XWINDOW (tem))
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
442 && ! (minibuf_level > 0 && EQ (tem, minibuf_window)))
6270
853b88dd9945 (Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents: 4696
diff changeset
443 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
444
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
445 /* 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
446 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
447 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
448
57998
a017cc23b31d (Fcall_interactively): Avoid reusing EVENT for other data.
Richard M. Stallman <rms@gnu.org>
parents: 57707
diff changeset
449 Fselect_window (tem, Qnil);
6270
853b88dd9945 (Fcall_interactively): Don't select an active minibuffer.
Karl Heuer <kwzh@gnu.org>
parents: 4696
diff changeset
450 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
451 string++;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
452 }
93542
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
453 else if (*string == '^')
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
454 {
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
455 if (! NILP (Vshift_select_mode))
93607
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
456 call1 (Qhandle_shift_selection, Qnil);
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
457 /* Even if shift-select-mode is off, temporarily active
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
458 regions could be set using the mouse, and should be
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
459 deactivated. */
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
460 else if (CONSP (Vtransient_mark_mode)
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
461 && EQ (XCAR (Vtransient_mark_mode), Qonly))
42db50d02ca0 (Fcall_interactively): Handle temporary region even when
Chong Yidong <cyd@stupidchicken.com>
parents: 93542
diff changeset
462 call1 (Qhandle_shift_selection, Qt);
93542
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
463 string++;
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
464 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
465 else break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
466 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
467
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
468 /* Count the number of arguments the interactive spec would have
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
469 us give to the function. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
470 tem = string;
81608
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
471 for (j = 0; *tem;)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
472 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
473 /* 'r' specifications ("point and mark as 2 numeric args")
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
474 produce *two* arguments. */
81608
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
475 if (*tem == 'r')
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
476 j += 2;
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
477 else
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
478 j++;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
479 tem = (unsigned char *) index (tem, '\n');
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
480 if (tem)
81608
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
481 ++tem;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
482 else
81608
75c51005f057 (Fcall_interactively): Make the parsing of interactive
David Kastrup <dak@gnu.org>
parents: 81285
diff changeset
483 break;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
484 }
13843
f5bd72a6fe48 (Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 13764
diff changeset
485 count = j;
407
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 args = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
488 visargs = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
489 varies = (int *) alloca ((count + 1) * sizeof (int));
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
490
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
491 for (i = 0; i < (count + 1); i++)
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 args[i] = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
494 visargs[i] = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
495 varies[i] = 0;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
496 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
497
57707
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
498 GCPRO5 (prefix_arg, function, *args, *visargs, up_event);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
499 gcpro3.nvars = (count + 1);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
500 gcpro4.nvars = (count + 1);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
501
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
502 if (!NILP (enable))
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
503 specbind (Qenable_recursive_minibuffers, Qt);
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
504
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
505 tem = string;
13843
f5bd72a6fe48 (Fcall_interactively): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 13764
diff changeset
506 for (i = 1; *tem; i++)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
507 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
508 strncpy (prompt1, tem + 1, sizeof prompt1 - 1);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
509 prompt1[sizeof prompt1 - 1] = 0;
31225
7930c46bb365 (toplevel) [HAVE_STRING_H]: Include string.h.
Gerd Moellmann <gerd@gnu.org>
parents: 29371
diff changeset
510 tem1 = (char *) index (prompt1, '\n');
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
511 if (tem1) *tem1 = 0;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
512
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
513 visargs[0] = build_string (prompt1);
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
514 if (index (prompt1, '%'))
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
515 callint_message = Fformat (i, visargs);
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
516 else
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
517 callint_message = visargs[0];
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
518
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
519 switch (*tem)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
520 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
521 case 'a': /* Symbol defined as a function */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
522 visargs[i] = Fcompleting_read (callint_message,
17736
8b30ef18c480 (Fcall_interactively): Pass new arg to
Richard M. Stallman <rms@gnu.org>
parents: 17024
diff changeset
523 Vobarray, Qfboundp, Qt,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
524 Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
525 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
526 teml = visargs[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
527 args[i] = Fintern (teml, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
528 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
529
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
530 case 'b': /* Name of existing buffer */
93400
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
531 args[i] = Fcurrent_buffer ();
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
532 if (EQ (selected_window, minibuf_window))
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
533 args[i] = Fother_buffer (args[i], Qnil, Qnil);
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
534 args[i] = Fread_buffer (callint_message, args[i], Qt);
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
535 break;
93013
6fb99dfc30ca (Fcall_interactively): For interactive code letters
Juri Linkov <juri@jurta.org>
parents: 91949
diff changeset
536
93400
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
537 case 'B': /* Name of buffer, possibly nonexistent */
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
538 args[i] = Fread_buffer (callint_message,
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
539 Fother_buffer (Fcurrent_buffer (), Qnil, Qnil),
82e99a4c7c09 (Fcall_interactively): Revert 2008-03-16 change
Juri Linkov <juri@jurta.org>
parents: 93109
diff changeset
540 Qnil);
407
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 'c': /* Character */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
544 args[i] = Fread_char (callint_message, Qnil, Qnil);
13754
8310d6085087 (Fcall_interactively): Don't log prompt strings.
Karl Heuer <kwzh@gnu.org>
parents: 13664
diff changeset
545 message1_nolog ((char *) 0);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
546 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
547 teml = args[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
548 visargs[i] = Fchar_to_string (teml);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
549 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
550
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
551 case 'C': /* Command: symbol with interactive function */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
552 visargs[i] = Fcompleting_read (callint_message,
17736
8b30ef18c480 (Fcall_interactively): Pass new arg to
Richard M. Stallman <rms@gnu.org>
parents: 17024
diff changeset
553 Vobarray, Qcommandp,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
554 Qt, Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
555 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
556 teml = visargs[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
557 args[i] = Fintern (teml, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
558 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
559
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
560 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
561 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
562 args[i] = point_marker;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
563 /* visargs[i] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
564 varies[i] = 1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
565 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
566
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
567 case 'D': /* Directory name. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
568 args[i] = Fread_file_name (callint_message, Qnil,
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
569 current_buffer->directory, Qlambda, Qnil,
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
570 Qfile_directory_p);
407
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 'f': /* Existing file name. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
574 args[i] = Fread_file_name (callint_message,
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
575 Qnil, Qnil, Qlambda, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
576 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
577
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
578 case 'F': /* Possibly nonexistent file name. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
579 args[i] = Fread_file_name (callint_message,
45546
ce01a38706ee (Fcall_interactively) <"D">: Supply Qfile_directory_p
Kim F. Storm <storm@cua.dk>
parents: 45394
diff changeset
580 Qnil, Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
581 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
582
60681
046708b92d49 (Finteractive): Document G option.
Richard M. Stallman <rms@gnu.org>
parents: 58380
diff changeset
583 case 'G': /* Possibly nonexistent file name,
046708b92d49 (Finteractive): Document G option.
Richard M. Stallman <rms@gnu.org>
parents: 58380
diff changeset
584 default to directory alone. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
585 args[i] = Fread_file_name (callint_message,
81285
d82619d66bd3 (Fdelete_and_extract_region): Use empty_unibyte_string.
Juanma Barranquero <lekktu@gmail.com>
parents: 75227
diff changeset
586 Qnil, Qnil, Qnil, empty_unibyte_string, Qnil);
60681
046708b92d49 (Finteractive): Document G option.
Richard M. Stallman <rms@gnu.org>
parents: 58380
diff changeset
587 break;
046708b92d49 (Finteractive): Document G option.
Richard M. Stallman <rms@gnu.org>
parents: 58380
diff changeset
588
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
589 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
590 varies[i] = -1;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
591 break;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
592
10540
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
593 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
594 {
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 46006
diff changeset
595 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
596 specbind (Qcursor_in_echo_area, Qt);
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
597 args[i] = Fread_key_sequence (callint_message,
22932
0e0275920715 (Fcall_interactively): Pass new arg to Fread_key_sequence.
Richard M. Stallman <rms@gnu.org>
parents: 22485
diff changeset
598 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
599 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
600 teml = args[i];
54927
7b6b4d9ae726 (Fkey_description): Change callers.
Kim F. Storm <storm@cua.dk>
parents: 54891
diff changeset
601 visargs[i] = Fkey_description (teml, Qnil);
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
602
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
603 /* 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
604 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
605 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
606 if (CONSP (teml))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
607 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
608 if (SYMBOLP (teml))
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 Lisp_Object tem2;
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
611
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
612 teml = Fget (teml, intern ("event-symbol-elements"));
24911
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
613 /* Ignore first element, which is the base key. */
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
614 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
615 if (! NILP (tem2))
72135
2bd7c2f5456f Change callers of read_char.
Chong Yidong <cyd@stupidchicken.com>
parents: 71969
diff changeset
616 up_event = Fread_event (Qnil, Qnil, Qnil);
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
617 }
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
618 }
10540
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
619 break;
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
620
161014ddd3c5 (Fcall_interactively): Define K mostly like k.
Richard M. Stallman <rms@gnu.org>
parents: 10345
diff changeset
621 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
622 {
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 46006
diff changeset
623 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
624 specbind (Qcursor_in_echo_area, Qt);
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
625 args[i] = Fread_key_sequence (callint_message,
22932
0e0275920715 (Fcall_interactively): Pass new arg to Fread_key_sequence.
Richard M. Stallman <rms@gnu.org>
parents: 22485
diff changeset
626 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
627 teml = args[i];
54927
7b6b4d9ae726 (Fkey_description): Change callers.
Kim F. Storm <storm@cua.dk>
parents: 54891
diff changeset
628 visargs[i] = Fkey_description (teml, 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
629 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
630
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
631 /* 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
632 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
633 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
634 if (CONSP (teml))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
635 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
636 if (SYMBOLP (teml))
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 Lisp_Object tem2;
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
639
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
640 teml = Fget (teml, intern ("event-symbol-elements"));
24911
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
641 /* Ignore first element, which is the base key. */
f477c5bb74c6 (Fcall_interactively): Ignore first element of
Andreas Schwab <schwab@suse.de>
parents: 23934
diff changeset
642 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
643 if (! NILP (tem2))
72135
2bd7c2f5456f Change callers of read_char.
Chong Yidong <cyd@stupidchicken.com>
parents: 71969
diff changeset
644 up_event = Fread_event (Qnil, Qnil, Qnil);
22485
b469abbc9984 (Fcall_interactively) <k, K>: If sequence ends in a down
Richard M. Stallman <rms@gnu.org>
parents: 22383
diff changeset
645 }
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
646 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
647 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
648
57707
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
649 case 'U': /* Up event from last k or K */
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
650 if (!NILP (up_event))
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
651 {
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
652 args[i] = Fmake_vector (make_number (1), up_event);
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
653 up_event = Qnil;
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
654 teml = args[i];
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
655 visargs[i] = Fkey_description (teml, Qnil);
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
656 }
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
657 break;
e092a2ece99b (Fcall_interactively): Add 'U' code to get the up-event discarded by a
Kim F. Storm <storm@cua.dk>
parents: 56571
diff changeset
658
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
659 case 'e': /* The invoking event. */
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
660 if (next_event >= key_count)
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
661 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
662 (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
663 ? (char *) SDATA (SYMBOL_NAME (function))
1383
54028d2538a4 * callint.c (Fcall_interactively): Allow multiple 'e' specs.
Jim Blandy <jimb@redhat.com>
parents: 1347
diff changeset
664 : "command"));
91949
d3395bc69ea8 (Fcall_interactively): Use AREF.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91911
diff changeset
665 args[i] = AREF (keys, next_event);
d3395bc69ea8 (Fcall_interactively): Use AREF.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91911
diff changeset
666 next_event++;
732
a8d94735277e *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
667 varies[i] = -1;
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
668
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
669 /* Find the next parameterized event. */
13308
99457b67e20c (Fcall_interactively): New arg KEYS.
Richard M. Stallman <rms@gnu.org>
parents: 13142
diff changeset
670 while (next_event < key_count
91949
d3395bc69ea8 (Fcall_interactively): Use AREF.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91911
diff changeset
671 && !(EVENT_HAS_PARAMETERS (AREF (keys, next_event))))
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
672 next_event++;
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1693
diff changeset
673
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
674 break;
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
675
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
676 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
677 check_mark (0);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
678 /* visargs[i] = Qnil; */
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
679 args[i] = current_buffer->mark;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
680 varies[i] = 2;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
681 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
682
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
683 case 'M': /* String read via minibuffer with
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
684 inheriting the current input method. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
685 args[i] = Fread_string (callint_message,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
686 Qnil, Qnil, Qnil, Qt);
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
687 break;
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
688
74912
4c1d868b634b (Finteractive): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 73441
diff changeset
689 case 'N': /* Prefix arg as number, else number from minibuffer */
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
690 if (!NILP (prefix_arg))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
691 goto have_prefix_arg;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
692 case 'n': /* Read number from minibuffer. */
15961
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 int first = 1;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
695 do
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 Lisp_Object tem;
71800
68b2027cba70 (Fcall_interactively): Update/simplify sit_for calls.
Kim F. Storm <storm@cua.dk>
parents: 70940
diff changeset
698 if (! first)
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 message ("Please enter a number.");
71800
68b2027cba70 (Fcall_interactively): Update/simplify sit_for calls.
Kim F. Storm <storm@cua.dk>
parents: 70940
diff changeset
701 sit_for (make_number (1), 0, 0);
15961
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
702 }
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
703 first = 0;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
704
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
705 tem = Fread_from_minibuffer (callint_message,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
706 Qnil, Qnil, Qnil, Qnil, Qnil,
70940
0143e273eaa8 (Fcall_interactively): Fread_from_minibuffer now takes only seven args.
Luc Teirlinck <teirllm@auburn.edu>
parents: 68651
diff changeset
707 Qnil);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46293
diff changeset
708 if (! STRINGP (tem) || SCHARS (tem) == 0)
15961
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
709 args[i] = Qnil;
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
710 else
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
711 args[i] = Fread (tem);
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
712 }
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
713 while (! NUMBERP (args[i]));
e26f5c2b75a6 (Fcall_interactively): For `N' and `n',
Richard M. Stallman <rms@gnu.org>
parents: 14847
diff changeset
714 }
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
715 visargs[i] = args[i];
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
716 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
717
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
718 case 'P': /* Prefix arg in raw form. Does no I/O. */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
719 args[i] = prefix_arg;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
720 /* visargs[i] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
721 varies[i] = -1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
722 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
723
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
724 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
725 have_prefix_arg:
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
726 args[i] = Fprefix_numeric_value (prefix_arg);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
727 /* visargs[i] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
728 varies[i] = -1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
729 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
730
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
731 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
732 check_mark (1);
20552
1a0cb8cd5615 (Fcall_interactively) <'d', 'r'>: Use set_marker_both.
Richard M. Stallman <rms@gnu.org>
parents: 19759
diff changeset
733 set_marker_both (point_marker, Qnil, PT, PT_BYTE);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
734 /* visargs[i+1] = Qnil; */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
735 foo = marker_position (current_buffer->mark);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
736 /* visargs[i] = Qnil; */
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15961
diff changeset
737 args[i] = PT < foo ? point_marker : current_buffer->mark;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
738 varies[i] = 3;
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15961
diff changeset
739 args[++i] = PT > foo ? point_marker : current_buffer->mark;
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
740 varies[i] = 4;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
741 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
742
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
743 case 's': /* String read via minibuffer without
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
744 inheriting the current input method. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
745 args[i] = Fread_string (callint_message,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
746 Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
747 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
748
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
749 case 'S': /* Any symbol. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
750 visargs[i] = Fread_string (callint_message,
19548
b275154db0cb (Finteractive): Document the code letter `M'.
Kenichi Handa <handa@m17n.org>
parents: 17958
diff changeset
751 Qnil, Qnil, Qnil, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
752 /* Passing args[i] directly stimulates compiler bug */
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
753 teml = visargs[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
754 args[i] = Fintern (teml, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
755 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
756
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
757 case 'v': /* Variable name: symbol that is
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
758 user-variable-p. */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
759 args[i] = Fread_variable (callint_message, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
760 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
761 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
762
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
763 case 'x': /* Lisp expression read but not evaluated */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
764 args[i] = Fread_minibuffer (callint_message, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
765 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
766 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
767
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
768 case 'X': /* Lisp expression read and evaluated */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
769 args[i] = Feval_minibuffer (callint_message, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
770 visargs[i] = last_minibuf_string;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
771 break;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
772
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
773 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
774 argument if no prefix */
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
775 if (NILP (prefix_arg))
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
776 {
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
777 args[i] = Qnil;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
778 varies[i] = -1;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
779 }
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48630
diff changeset
780 else
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
781 {
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
782 args[i]
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
783 = Fread_non_nil_coding_system (callint_message);
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
784 visargs[i] = last_minibuf_string;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
785 }
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
786 break;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
787
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
788 case 'z': /* Coding-system symbol or nil */
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
789 args[i] = Fread_coding_system (callint_message, Qnil);
17024
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
790 visargs[i] = last_minibuf_string;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
791 break;
6cfba7f41dca (doc-string of `interactive'): Describe new code
Karl Heuer <kwzh@gnu.org>
parents: 16363
diff changeset
792
11278
25b2219c415c (Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents: 11009
diff changeset
793 /* 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
794 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
795 case '+':
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
796 default:
11278
25b2219c415c (Fcall_interactively): `+' is reserved for user changes.
Richard M. Stallman <rms@gnu.org>
parents: 11009
diff changeset
797 error ("Invalid control letter `%c' (%03o) in interactive calling string",
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
798 *tem, *tem);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
799 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
800
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
801 if (varies[i] == 0)
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
802 arg_from_tty = 1;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
803
9145
dda75a4dbbfb (quotify_arg, Fcall_interactively, Fprefix_numeric_value): Use type test
Karl Heuer <kwzh@gnu.org>
parents: 9100
diff changeset
804 if (NILP (visargs[i]) && STRINGP (args[i]))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
805 visargs[i] = args[i];
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
806
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
807 tem = (unsigned char *) index (tem, '\n');
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
808 if (tem) tem++;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
809 else tem = (unsigned char *) "";
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
810 }
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
811 unbind_to (speccount, Qnil);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
812
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
813 QUIT;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
814
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
815 args[0] = function;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
816
14062
16a05061fee3 (Fcall_interactively, Fprefix_numeric_value): Harmonize arguments with
Erik Naggum <erik@naggum.no>
parents: 13843
diff changeset
817 if (arg_from_tty || !NILP (record_flag))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
818 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
819 visargs[0] = function;
438
8b54ee2c82d6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 407
diff changeset
820 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
821 {
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
822 if (varies[i] > 0)
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
823 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
824 else
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
825 visargs[i] = quotify_arg (args[i]);
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
826 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
827 Vcommand_history = Fcons (Flist (count + 1, visargs),
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
828 Vcommand_history);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
829 /* Don't keep command history around forever. */
44405
0ed69545b5f3 (Fcall_interactively): Use INTEGERP instead of
Gerd Moellmann <gerd@gnu.org>
parents: 43039
diff changeset
830 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
831 {
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
832 teml = Fnthcdr (Vhistory_length, Vcommand_history);
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
833 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
834 XSETCDR (teml, Qnil);
21721
46ffb5302c40 (Fcall_interactively): Truncate command-history here.
Richard M. Stallman <rms@gnu.org>
parents: 21514
diff changeset
835 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
836 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
837
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
838 /* 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
839 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
840 for (i = 1; i <= count; i++)
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
841 if (varies[i] >= 1 && varies[i] <= 4)
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
842 XSETINT (args[i], marker_position (args[i]));
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
843
48527
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
844 if (record_then_fail)
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
845 Fbarf_if_buffer_read_only ();
ba7cb9f8dfc3 (Fcall_interactively): If a command fails because
Richard M. Stallman <rms@gnu.org>
parents: 48150
diff changeset
846
52374
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
847 Vthis_command = save_this_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
848 Vthis_original_command = save_this_original_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
849 real_this_command= save_real_this_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
850 current_kboard->Vlast_command = save_last_command;
1b48f538540b (Fcall_interactively): Save and restore Vthis_command, Vthis_original_command,
Richard M. Stallman <rms@gnu.org>
parents: 51048
diff changeset
851
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
852 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
853 Lisp_Object val;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
854 specbind (Qcommand_debug_status, Qnil);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
855
83449
ff74a86c2b16 Overhaul and simplify single_kboard API. Allow calls to `recursive-edit' in process filters. Small fixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83374
diff changeset
856 temporarily_switch_to_single_kboard (NULL);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
857 val = Ffuncall (count + 1, args);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
858 UNGCPRO;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
859 return unbind_to (speccount, val);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
860 }
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48630
diff changeset
861 }
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
862
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
863 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
864 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
865 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
866 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
867 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
868 (raw)
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
869 Lisp_Object raw;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
870 {
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
871 Lisp_Object val;
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48630
diff changeset
872
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 438
diff changeset
873 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
874 XSETFASTINT (val, 1);
819
5bbabfcef929 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 732
diff changeset
875 else if (EQ (raw, Qminus))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
876 XSETINT (val, -1);
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 24911
diff changeset
877 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
878 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
879 else if (INTEGERP (raw))
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
880 val = raw;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
881 else
9298
6e3aea54fc01 (Fcall_interactively, Fprefix_numeric_value): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents: 9290
diff changeset
882 XSETFASTINT (val, 1);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
883
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
884 return val;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
885 }
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
886
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21244
diff changeset
887 void
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
888 syms_of_callint ()
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
889 {
10803
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
890 point_marker = Fmake_marker ();
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
891 staticpro (&point_marker);
b8c4a1b7d484 (Fcall_interactively): Use markers temporarily in
Richard M. Stallman <rms@gnu.org>
parents: 10756
diff changeset
892
73441
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
893 callint_message = Qnil;
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
894 staticpro (&callint_message);
82ed0adffca9 * callint.c (callint_message): Convert to a Lisp string.
Chong Yidong <cyd@stupidchicken.com>
parents: 73120
diff changeset
895
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
896 preserved_fns = Fcons (intern ("region-beginning"),
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
897 Fcons (intern ("region-end"),
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
898 Fcons (intern ("point"),
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
899 Fcons (intern ("mark"), Qnil))));
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
900 staticpro (&preserved_fns);
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
901
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
902 Qlist = intern ("list");
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
903 staticpro (&Qlist);
13447
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
904 Qlet = intern ("let");
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
905 staticpro (&Qlet);
49932
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
906 Qif = intern ("if");
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
907 staticpro (&Qif);
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
908 Qwhen = intern ("when");
2f5cdffaaa04 (fix_command): New subroutine, from Fcall_interactively.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
909 staticpro (&Qwhen);
13447
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
910 Qletx = intern ("let*");
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
911 staticpro (&Qletx);
8c89b569cfa9 (syms_of_callint): Set up Qlet, Qletx, Qsave_excursion.
Richard M. Stallman <rms@gnu.org>
parents: 13308
diff changeset
912 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
913 staticpro (&Qsave_excursion);
48150
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
914 Qprogn = intern ("progn");
2b5f7e1254d1 (Fcall_interactively): New local filter_specs.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
915 staticpro (&Qprogn);
1498
098464e977d6 (preserved_fns): New var.
Richard M. Stallman <rms@gnu.org>
parents: 1425
diff changeset
916
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
917 Qminus = intern ("-");
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
918 staticpro (&Qminus);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
919
9100
7dacd83e0fe0 (Qplus): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8819
diff changeset
920 Qplus = intern ("+");
7dacd83e0fe0 (Qplus): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8819
diff changeset
921 staticpro (&Qplus);
7dacd83e0fe0 (Qplus): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8819
diff changeset
922
93542
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
923 Qhandle_shift_selection = intern ("handle-shift-selection");
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
924 staticpro (&Qhandle_shift_selection);
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
925
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
926 Qcall_interactively = intern ("call-interactively");
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
927 staticpro (&Qcall_interactively);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
928
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
929 Qcommand_debug_status = intern ("command-debug-status");
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
930 staticpro (&Qcommand_debug_status);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
931
873
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
932 Qenable_recursive_minibuffers = intern ("enable-recursive-minibuffers");
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
933 staticpro (&Qenable_recursive_minibuffers);
0abaf590e0ca entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 863
diff changeset
934
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
935 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
936 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
937
12117
3fa5b6e7ad4b (current_prefix_partial): Deleted.
Karl Heuer <kwzh@gnu.org>
parents: 11911
diff changeset
938 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
939 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
940 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
941 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
942 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
943
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
944 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
945 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
946 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
947 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
948
22383
9ef0fe84c5ed (syms_of_callint): Set up Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 22244
diff changeset
949 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
950 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
951 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
952
10857
2b9faff73319 (Fcall_interactively, syms_of_callint, Vprefix_arg, Vcurrent_prefix_arg): Undo
Karl Heuer <kwzh@gnu.org>
parents: 10846
diff changeset
953 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
954 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
955 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
956 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
957 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
958 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
959 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
960
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
961 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
962 doc: /* List of recent commands that read arguments from terminal.
79601
e6ee871046f8 (syms_of_callint) <command-history>: Add reference to history-length in
Eli Zaretskii <eliz@gnu.org>
parents: 78260
diff changeset
963 Each command is represented as a form to evaluate.
e6ee871046f8 (syms_of_callint) <command-history>: Add reference to history-length in
Eli Zaretskii <eliz@gnu.org>
parents: 78260
diff changeset
964
e6ee871046f8 (syms_of_callint) <command-history>: Add reference to history-length in
Eli Zaretskii <eliz@gnu.org>
parents: 78260
diff changeset
965 Maximum length of the history list is determined by the value
e6ee871046f8 (syms_of_callint) <command-history>: Add reference to history-length in
Eli Zaretskii <eliz@gnu.org>
parents: 78260
diff changeset
966 of `history-length', which see. */);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
967 Vcommand_history = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
968
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
969 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
970 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
971 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
972 may be set by the debugger as a reminder for itself. */);
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
973 Vcommand_debug_status = Qnil;
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
974
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
975 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
976 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
977 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
978 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
979 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
980 behave as if the mark were still active. */);
91911
07b62dd00afa * simple.el (transient-mark-mode): Add an :init-value.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 87649
diff changeset
981 Vmark_even_if_inactive = Qt;
3975
718280a1ba74 (Vmark_even_if_inactive): New var, with Lisp variable.
Richard M. Stallman <rms@gnu.org>
parents: 2048
diff changeset
982
93542
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
983 DEFVAR_LISP ("shift-select-mode", &Vshift_select_mode,
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
984 doc: /* When non-nil, shifted motion keys activate the mark momentarily.
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
985
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
986 While the mark is activated in this way, any shift-translated point
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
987 motion key extends the region, and if Transient Mark mode was off, it
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
988 is temporarily turned on. Furthermore, the mark will be deactivated
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
989 by any subsequent point motion key that was not shift-translated, or
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
990 by any action that normally deactivates the mark in Transient Mark
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
991 mode.
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
992
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
993 See `this-command-keys-shift-translated' for the meaning of
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
994 shift-translation. */);
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
995 Vshift_select_mode = Qt;
5dd7fdf8c27e (Vshift_select_mode): New var.
Chong Yidong <cyd@stupidchicken.com>
parents: 93400
diff changeset
996
10279
89cf458ed188 (Vmouse_leave_buffer_hook, Qmouse_leave_buffer_hook): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 9342
diff changeset
997 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
998 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
999 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
1000 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
1001 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
1002
407
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
1003 defsubr (&Sinteractive);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
1004 defsubr (&Scall_interactively);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
1005 defsubr (&Sprefix_numeric_value);
a82d2d892c89 Initial revision
Michael I. Bushnell <mib@gnu.org>
parents:
diff changeset
1006 }
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52374
diff changeset
1007
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52374
diff changeset
1008 /* arch-tag: a3a7cad7-bcac-42ce-916e-1bd2546ebf37
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52374
diff changeset
1009 (do not change this comment) */