Version 2.0.21 released.
[emacs.git] / src / commands.h
blobd830573b58b13a2ee0ae1cd1a83affc04844ad55
1 /* Definitions needed by most editing commands.
2 Copyright (C) 1985, 1994 Free Software Foundation, Inc.
4 This file is part of GNU Emacs.
6 GNU Emacs is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
9 any later version.
11 GNU Emacs is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU Emacs; see the file COPYING. If not, write to
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA. */
22 #define Ctl(c) ((c)&037)
24 /* Define the names of keymaps, just so people can refer to them in
25 calls to initial_define_key. These should *not* be used after
26 initialization; use-global-map doesn't affect these; it sets
27 current_global_map instead. */
28 extern Lisp_Object global_map;
29 extern Lisp_Object meta_map;
30 extern Lisp_Object control_x_map;
32 extern Lisp_Object Vminibuffer_local_map;
34 extern Lisp_Object Vminibuffer_local_ns_map;
36 /* keymap used for minibuffers when doing completion */
37 extern Lisp_Object Vminibuffer_local_completion_map;
39 /* keymap used for minibuffers when doing completion and require a match */
40 extern Lisp_Object Vminibuffer_local_must_match_map;
42 /* Last character of last key sequence. */
43 extern Lisp_Object last_command_char;
45 /* Last input character read as a command, not counting menus
46 reached by the mouse. */
47 extern Lisp_Object last_nonmenu_event;
49 /* List of command events to be re-read, or Qnil. */
50 extern Lisp_Object Vunread_command_events;
52 /* Command char event to be re-read, or -1 if none.
53 Setting this is obsolete, but some things should still check it. */
54 extern EMACS_INT unread_command_char;
56 /* The command being executed by the command loop.
57 Commands may set this, and the value set will be copied into
58 current_kboard->Vlast_command instead of the actual command. */
59 extern Lisp_Object Vthis_command;
61 /* If not Qnil, this is a switch-frame event which we decided to put
62 off until the end of a key sequence. This should be read as the
63 next command input, after any Vunread_command_events.
65 read_key_sequence uses this to delay switch-frame events until the
66 end of the key sequence; Fread_char uses it to put off switch-frame
67 events until a non-ASCII event is acceptable as input. */
68 extern Lisp_Object unread_switch_frame;
70 /* The value of point when the last command was executed. */
71 extern int last_point_position;
73 /* The buffer that was current when the last command was started. */
74 extern Lisp_Object last_point_position_buffer;
76 /* Nonzero means ^G can quit instantly */
77 extern int immediate_quit;
79 extern Lisp_Object Vexecuting_macro;
81 /* Nonzero if input is coming from the keyboard */
83 #define INTERACTIVE (NILP (Vexecuting_macro) && !noninteractive)
85 /* Set this nonzero to force reconsideration of mode line. */
87 extern int update_mode_lines;
89 /* Nonzero means reading single-character input with prompt
90 so put cursor on minibuffer after the prompt. */
92 extern int cursor_in_echo_area;