1 /* Definitions needed by most editing commands.
2 Copyright (C) 1985, 1994, 2002, 2003, 2004,
3 2005 Free Software Foundation, Inc.
5 This file is part of GNU Emacs.
7 GNU Emacs is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
12 GNU Emacs is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GNU Emacs; see the file COPYING. If not, write to
19 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20 Boston, MA 02110-1301, USA. */
23 #define Ctl(c) ((c)&037)
25 /* Define the names of keymaps, just so people can refer to them in
26 calls to initial_define_key. These should *not* be used after
27 initialization; use-global-map doesn't affect these; it sets
28 current_global_map instead. */
29 extern Lisp_Object global_map
;
30 extern Lisp_Object meta_map
;
31 extern Lisp_Object control_x_map
;
33 extern Lisp_Object Vminibuffer_local_map
;
35 extern Lisp_Object Vminibuffer_local_ns_map
;
37 /* keymap used for minibuffers when doing completion */
38 extern Lisp_Object Vminibuffer_local_completion_map
;
40 /* keymap used for minibuffers when doing completion and require a match */
41 extern Lisp_Object Vminibuffer_local_must_match_map
;
43 /* Last character of last key sequence. */
44 extern Lisp_Object last_command_char
;
46 /* Last input character read as a command, not counting menus
47 reached by the mouse. */
48 extern Lisp_Object last_nonmenu_event
;
50 /* List of command events to be re-read, or Qnil. */
51 extern Lisp_Object Vunread_command_events
;
53 /* Command char event to be re-read, or -1 if none.
54 Setting this is obsolete, but some things should still check it. */
55 extern EMACS_INT unread_command_char
;
57 /* The command being executed by the command loop.
58 Commands may set this, and the value set will be copied into
59 current_kboard->Vlast_command instead of the actual command. */
60 extern Lisp_Object Vthis_command
;
62 /* If not Qnil, this is a switch-frame event which we decided to put
63 off until the end of a key sequence. This should be read as the
64 next command input, after any Vunread_command_events.
66 read_key_sequence uses this to delay switch-frame events until the
67 end of the key sequence; Fread_char uses it to put off switch-frame
68 events until a non-ASCII event is acceptable as input. */
69 extern Lisp_Object unread_switch_frame
;
71 /* The value of point when the last command was executed. */
72 extern int last_point_position
;
74 /* The buffer that was current when the last command was started. */
75 extern Lisp_Object last_point_position_buffer
;
77 /* Nonzero means ^G can quit instantly */
78 extern int immediate_quit
;
80 extern Lisp_Object Vexecuting_kbd_macro
;
82 /* Nonzero if input is coming from the keyboard */
84 #define INTERACTIVE (NILP (Vexecuting_kbd_macro) && !noninteractive)
86 /* Set this nonzero to force reconsideration of mode line. */
88 extern int update_mode_lines
;
90 /* Nonzero means reading single-character input with prompt
91 so put cursor on minibuffer after the prompt. */
93 extern int cursor_in_echo_area
;
95 /* arch-tag: 4f7ca0b7-6a56-4b20-8bf5-b67a99921d1d
96 (do not change this comment) */