(cvs-parse-run-table): Remove misleading text.
[bpt/emacs.git] / src / cmds.c
CommitLineData
cd645247 1/* Simple built-in editing commands.
4a2f9c6a 2 Copyright (C) 1985, 93, 94, 95, 96, 97, 1998 Free Software Foundation, Inc.
cd645247
JB
3
4This file is part of GNU Emacs.
5
6GNU Emacs is free software; you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
502ddf23 8the Free Software Foundation; either version 2, or (at your option)
cd645247
JB
9any later version.
10
11GNU Emacs is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU Emacs; see the file COPYING. If not, write to
3b7ad313
EN
18the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19Boston, MA 02111-1307, USA. */
cd645247
JB
20
21
18160b98 22#include <config.h>
cd645247
JB
23#include "lisp.h"
24#include "commands.h"
25#include "buffer.h"
9e4fd67b 26#include "charset.h"
cd645247 27#include "syntax.h"
f109dfa2 28#include "window.h"
346e0c2d 29#include "keyboard.h"
dfcf069d 30#include "dispextern.h"
cd645247
JB
31
32Lisp_Object Qkill_forward_chars, Qkill_backward_chars, Vblink_paren_function;
33
6bbb0d4a
JB
34/* A possible value for a buffer's overwrite-mode variable. */
35Lisp_Object Qoverwrite_mode_binary;
36
189fad68
RS
37/* Non-nil means put this face on the next self-inserting character. */
38Lisp_Object Vself_insert_face;
39
40/* This is the command that set up Vself_insert_face. */
41Lisp_Object Vself_insert_face_command;
42
189fad68 43extern Lisp_Object Qface;
cd645247 44\f
9e4fd67b
KH
45DEFUN ("forward-point", Fforward_point, Sforward_point, 1, 1, 0,
46 "Return buffer position N characters after (before if N negative) point.")
47 (n)
48 Lisp_Object n;
49{
50 CHECK_NUMBER (n, 0);
51
049749e6 52 return make_number (PT + XINT (n));
9e4fd67b
KH
53}
54
cd645247 55DEFUN ("forward-char", Fforward_char, Sforward_char, 0, 1, "p",
72d5f589 56 "Move point right N characters (left if N is negative).\n\
cd645247 57On reaching end of buffer, stop and signal error.")
72d5f589
EN
58 (n)
59 Lisp_Object n;
cd645247 60{
72d5f589
EN
61 if (NILP (n))
62 XSETFASTINT (n, 1);
cd645247 63 else
72d5f589 64 CHECK_NUMBER (n, 0);
cd645247 65
72d5f589 66 /* This used to just set point to point + XINT (n), and then check
7b502dc3
JB
67 to see if it was within boundaries. But now that SET_PT can
68 potentially do a lot of stuff (calling entering and exiting
69 hooks, etcetera), that's not a good approach. So we validate the
70 proposed position, then set point. */
71 {
049749e6 72 int new_point = PT + XINT (n);
7b502dc3
JB
73
74 if (new_point < BEGV)
75 {
76 SET_PT (BEGV);
77 Fsignal (Qbeginning_of_buffer, Qnil);
78 }
79 if (new_point > ZV)
80 {
81 SET_PT (ZV);
82 Fsignal (Qend_of_buffer, Qnil);
83 }
84
85 SET_PT (new_point);
86 }
87
cd645247
JB
88 return Qnil;
89}
90
91DEFUN ("backward-char", Fbackward_char, Sbackward_char, 0, 1, "p",
72d5f589 92 "Move point left N characters (right if N is negative).\n\
cd645247 93On attempt to pass beginning or end of buffer, stop and signal error.")
72d5f589
EN
94 (n)
95 Lisp_Object n;
cd645247 96{
72d5f589
EN
97 if (NILP (n))
98 XSETFASTINT (n, 1);
cd645247 99 else
72d5f589 100 CHECK_NUMBER (n, 0);
cd645247 101
72d5f589
EN
102 XSETINT (n, - XINT (n));
103 return Fforward_char (n);
cd645247
JB
104}
105
106DEFUN ("forward-line", Fforward_line, Sforward_line, 0, 1, "p",
72d5f589
EN
107 "Move N lines forward (backward if N is negative).\n\
108Precisely, if point is on line I, move to the start of line I + N.\n\
cd645247
JB
109If there isn't room, go as far as possible (no error).\n\
110Returns the count of lines left to move. If moving forward,\n\
72d5f589
EN
111that is N - number of lines moved; if backward, N + number moved.\n\
112With positive N, a non-empty line at the end counts as one line\n\
cd645247
JB
113 successfully moved (for the return value).")
114 (n)
115 Lisp_Object n;
116{
049749e6
RS
117 int opoint = PT, opoint_byte = PT_BYTE;
118 int pos, pos_byte;
119 int count, shortage;
cd645247 120
265a9e55 121 if (NILP (n))
cd645247
JB
122 count = 1;
123 else
124 {
125 CHECK_NUMBER (n, 0);
126 count = XINT (n);
127 }
128
049749e6
RS
129 if (count <= 0)
130 shortage = scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, count - 1, 1);
131 else
132 shortage = scan_newline (PT, PT_BYTE, ZV, ZV_BYTE, count, 1);
133
134 /* Since scan_newline does TEMP_SET_PT_BOTH,
135 and we want to set PT "for real",
136 go back to the old point and then come back here. */
137 pos = PT;
138 pos_byte = PT_BYTE;
139 TEMP_SET_PT_BOTH (opoint, opoint_byte);
140 SET_PT_BOTH (pos, pos_byte);
141
cd645247 142 if (shortage > 0
049749e6 143 && (count <= 0
502ddf23 144 || (ZV > BEGV
049749e6
RS
145 && PT != opoint
146 && (FETCH_BYTE (PT_BYTE - 1) != '\n'))))
cd645247 147 shortage--;
049749e6
RS
148
149 return make_number (count <= 0 ? - shortage : shortage);
cd645247
JB
150}
151
152DEFUN ("beginning-of-line", Fbeginning_of_line, Sbeginning_of_line,
153 0, 1, "p",
154 "Move point to beginning of current line.\n\
72d5f589 155With argument N not nil or 1, move forward N - 1 lines first.\n\
c252ce76
RS
156If point reaches the beginning or end of buffer, it stops there.\n\
157This command does not move point across a field boundary\n\
158unless it would move beyond there to a different line.\n\
159If N is nil or 1, and point starts at a field boundary, point does not move.")
cd645247
JB
160 (n)
161 Lisp_Object n;
162{
265a9e55 163 if (NILP (n))
48c7cef2 164 XSETFASTINT (n, 1);
cd645247
JB
165 else
166 CHECK_NUMBER (n, 0);
167
0aee588d 168 SET_PT (XINT (Fline_beginning_position (n)));
4f13cc99 169
cd645247
JB
170 return Qnil;
171}
172
173DEFUN ("end-of-line", Fend_of_line, Send_of_line,
174 0, 1, "p",
175 "Move point to end of current line.\n\
72d5f589 176With argument N not nil or 1, move forward N - 1 lines first.\n\
c252ce76
RS
177If point reaches the beginning or end of buffer, it stops there.\n\
178This command does not move point across a field boundary\n\
179unless it would move beyond there to a different line.\n\
180If N is nil or 1, and point starts at a field boundary, point does not move.")
cd645247
JB
181 (n)
182 Lisp_Object n;
183{
265a9e55 184 if (NILP (n))
48c7cef2 185 XSETFASTINT (n, 1);
cd645247
JB
186 else
187 CHECK_NUMBER (n, 0);
188
38b294ca 189 SET_PT (XINT (Fline_end_position (n)));
cd645247
JB
190
191 return Qnil;
192}
193
194DEFUN ("delete-char", Fdelete_char, Sdelete_char, 1, 2, "p\nP",
72d5f589 195 "Delete the following N characters (previous if N is negative).\n\
cd645247 196Optional second arg KILLFLAG non-nil means kill instead (save in kill ring).\n\
72d5f589
EN
197Interactively, N is the prefix arg, and KILLFLAG is set if\n\
198N was explicitly specified.")
cd645247
JB
199 (n, killflag)
200 Lisp_Object n, killflag;
201{
9e4fd67b
KH
202 int pos;
203
cd645247
JB
204 CHECK_NUMBER (n, 0);
205
049749e6 206 pos = PT + XINT (n);
265a9e55 207 if (NILP (killflag))
cd645247
JB
208 {
209 if (XINT (n) < 0)
210 {
9e4fd67b 211 if (pos < BEGV)
cd645247
JB
212 Fsignal (Qbeginning_of_buffer, Qnil);
213 else
9e4fd67b 214 del_range (pos, PT);
cd645247
JB
215 }
216 else
217 {
9e4fd67b 218 if (pos > ZV)
cd645247
JB
219 Fsignal (Qend_of_buffer, Qnil);
220 else
9e4fd67b 221 del_range (PT, pos);
cd645247
JB
222 }
223 }
224 else
225 {
226 call1 (Qkill_forward_chars, n);
227 }
228 return Qnil;
229}
230
231DEFUN ("delete-backward-char", Fdelete_backward_char, Sdelete_backward_char,
232 1, 2, "p\nP",
72d5f589 233 "Delete the previous N characters (following if N is negative).\n\
cd645247 234Optional second arg KILLFLAG non-nil means kill instead (save in kill ring).\n\
72d5f589
EN
235Interactively, N is the prefix arg, and KILLFLAG is set if\n\
236N was explicitly specified.")
cd645247
JB
237 (n, killflag)
238 Lisp_Object n, killflag;
239{
aa970069 240 Lisp_Object value;
7c983171 241 int deleted_special = 0;
ceb7e4f8 242 int pos, pos_byte, i;
aa970069 243
cd645247 244 CHECK_NUMBER (n, 0);
aa970069 245
7c983171 246 /* See if we are about to delete a tab or newline backwards. */
ceb7e4f8
KH
247 pos = PT;
248 pos_byte = PT_BYTE;
249 for (i = 0; i < XINT (n) && pos_byte > BEGV_BYTE; i++)
aa970069 250 {
9e4fd67b
KH
251 int c;
252
ceb7e4f8
KH
253 DEC_BOTH (pos, pos_byte);
254 c = FETCH_BYTE (pos_byte);
9e4fd67b 255 if (c == '\t' || c == '\n')
aa970069 256 {
7c983171 257 deleted_special = 1;
aa970069
RS
258 break;
259 }
260 }
261
aa970069
RS
262 /* In overwrite mode, back over columns while clearing them out,
263 unless at end of line. */
264 if (XINT (n) > 0
265 && ! NILP (current_buffer->overwrite_mode)
7c983171 266 && ! deleted_special
049749e6 267 && ! (PT == ZV || FETCH_BYTE (PT_BYTE) == '\n'))
aa970069 268 {
9e4fd67b
KH
269 int column = current_column ();
270
271 value = Fdelete_char (make_number (-XINT (n)), killflag);
272 i = column - current_column ();
cac55749 273 Finsert_char (make_number (' '), make_number (i), Qnil);
049749e6
RS
274 /* Whitespace chars are ASCII chars, so we can simply subtract. */
275 SET_PT_BOTH (PT - i, PT_BYTE - i);
aa970069 276 }
9e4fd67b
KH
277 else
278 value = Fdelete_char (make_number (-XINT (n)), killflag);
aa970069
RS
279
280 return value;
cd645247
JB
281}
282
283DEFUN ("self-insert-command", Fself_insert_command, Sself_insert_command, 1, 1, "p",
284 "Insert the character you type.\n\
285Whichever character you type to run this command is inserted.")
72d5f589
EN
286 (n)
287 Lisp_Object n;
cd645247 288{
a22ca1e0
RS
289 int character = XINT (last_command_char);
290
72d5f589 291 CHECK_NUMBER (n, 0);
cd645247
JB
292
293 /* Barf if the key that invoked this was not a character. */
ed76f667 294 if (!INTEGERP (last_command_char))
cd645247 295 bitch_at_user ();
72d5f589 296 else if (XINT (n) >= 2 && NILP (current_buffer->overwrite_mode))
2718dfa4 297 {
a22ca1e0
RS
298 int modified_char = character;
299 /* Add the offset to the character, for Finsert_char.
300 We pass internal_self_insert the unmodified character
301 because it itself does this offsetting. */
49bc32b0
RS
302 if (! NILP (current_buffer->enable_multibyte_characters))
303 modified_char = unibyte_char_to_multibyte (modified_char);
a22ca1e0 304
72d5f589 305 XSETFASTINT (n, XFASTINT (n) - 2);
2718dfa4 306 /* The first one might want to expand an abbrev. */
a22ca1e0 307 internal_self_insert (character, 1);
2718dfa4
RS
308 /* The bulk of the copies of this char can be inserted simply.
309 We don't have to handle a user-specified face specially
310 because it will get inherited from the first char inserted. */
a22ca1e0 311 Finsert_char (make_number (modified_char), n, Qt);
2718dfa4 312 /* The last one might want to auto-fill. */
a22ca1e0 313 internal_self_insert (character, 0);
2718dfa4 314 }
cd645247 315 else
72d5f589 316 while (XINT (n) > 0)
cd645247 317 {
f58dd69b 318 /* Ok since old and new vals both nonneg */
72d5f589 319 XSETFASTINT (n, XFASTINT (n) - 1);
a22ca1e0 320 internal_self_insert (character, XFASTINT (n) != 0);
cd645247
JB
321 }
322
323 return Qnil;
324}
325
9e4fd67b 326/* Insert character C. If NOAUTOFILL is nonzero, don't do autofill
4c6e656f
RS
327 even if it is enabled.
328
329 If this insertion is suitable for direct output (completely simple),
aa52fef9
RS
330 return 0. A value of 1 indicates this *might* not have been simple.
331 A value of 2 means this did things that call for an undo boundary. */
4c6e656f 332
dfcf069d 333int
9e4fd67b
KH
334internal_self_insert (c, noautofill)
335 int c;
cd645247
JB
336 int noautofill;
337{
338 extern Lisp_Object Fexpand_abbrev ();
339 int hairy = 0;
340 Lisp_Object tem;
341 register enum syntaxcode synt;
e744155a 342 Lisp_Object overwrite, string;
9e4fd67b
KH
343 /* Length of multi-byte form of C. */
344 int len;
345 /* Working buffer and pointer for multi-byte form of C. */
e55d9cfd 346 unsigned char str[MAX_MULTIBYTE_LENGTH];
049749e6 347 int chars_to_delete = 0;
e744155a 348 int spaces_to_insert = 0;
cd645247 349
e7aacab7 350 overwrite = current_buffer->overwrite_mode;
ad44dffe 351 if (!NILP (Vbefore_change_functions) || !NILP (Vafter_change_functions))
cd645247
JB
352 hairy = 1;
353
9e4fd67b
KH
354 /* At first, get multi-byte form of C in STR. */
355 if (!NILP (current_buffer->enable_multibyte_characters))
b9859007
KH
356 {
357 c = unibyte_char_to_multibyte (c);
e55d9cfd 358 len = CHAR_STRING (c, str);
741263c2
KH
359 if (len == 1)
360 /* If C has modifier bits, this makes C an appropriate
361 one-byte char. */
362 c = *str;
b9859007 363 }
9e4fd67b 364 else
38b62842 365 {
e55d9cfd
KH
366 str[0] = (SINGLE_BYTE_CHAR_P (c)
367 ? c
368 : multibyte_char_to_unibyte (c, Qnil));
38b62842
KH
369 len = 1;
370 }
6bbb0d4a 371 if (!NILP (overwrite)
9e4fd67b 372 && PT < ZV)
cd645247 373 {
9e4fd67b
KH
374 /* In overwrite-mode, we substitute a character at point (C2,
375 hereafter) by C. For that, we delete C2 in advance. But,
376 just substituting C2 by C may move a remaining text in the
377 line to the right or to the left, which is not preferable.
378 So we insert more spaces or delete more characters in the
379 following cases: if C is narrower than C2, after deleting C2,
380 we fill columns with spaces, if C is wider than C2, we delete
381 C2 and several characters following C2. */
382
216b9443
RS
383 /* This is the character after point. */
384 int c2 = FETCH_CHAR (PT_BYTE);
385
386 /* Column the cursor should be placed at after this insertion.
9e4fd67b
KH
387 The correct value should be calculated only when necessary. */
388 int target_clm = 0;
389
37c0ed09
RS
390 /* Overwriting in binary-mode always replaces C2 by C.
391 Overwriting in textual-mode doesn't always do that.
392 It inserts newlines in the usual way,
393 and inserts any character at end of line
394 or before a tab if it doesn't use the whole width of the tab. */
9e4fd67b
KH
395 if (EQ (overwrite, Qoverwrite_mode_binary)
396 || (c != '\n'
397 && c2 != '\n'
37c0ed09
RS
398 && ! (c2 == '\t'
399 && XINT (current_buffer->tab_width) > 0
400 && XFASTINT (current_buffer->tab_width) < 20
216b9443 401 && (target_clm = (current_column ()
06d74a65 402 + XINT (Fchar_width (make_number (c)))),
37c0ed09 403 target_clm % XFASTINT (current_buffer->tab_width)))))
9e4fd67b 404 {
e744155a 405 int pos = PT;
049749e6 406 int pos_byte = PT_BYTE;
e744155a 407
9e4fd67b 408 if (target_clm == 0)
049749e6 409 chars_to_delete = 1;
9e4fd67b
KH
410 else
411 {
9e4fd67b
KH
412 /* The actual cursor position after the trial of moving
413 to column TARGET_CLM. It is greater than TARGET_CLM
414 if the TARGET_CLM is middle of multi-column
415 character. In that case, the new point is set after
416 that character. */
cac55749
RS
417 int actual_clm
418 = XFASTINT (Fmove_to_column (make_number (target_clm), Qnil));
9e4fd67b 419
049749e6 420 chars_to_delete = PT - pos;
e744155a 421
9e4fd67b
KH
422 if (actual_clm > target_clm)
423 {
e744155a 424 /* We will delete too many columns. Let's fill columns
9e4fd67b 425 by spaces so that the remaining text won't move. */
e744155a 426 spaces_to_insert = actual_clm - target_clm;
9e4fd67b
KH
427 }
428 }
049749e6 429 SET_PT_BOTH (pos, pos_byte);
9e4fd67b
KH
430 hairy = 2;
431 }
aa52fef9 432 hairy = 2;
cd645247 433 }
265a9e55 434 if (!NILP (current_buffer->abbrev_mode)
cd645247 435 && SYNTAX (c) != Sword
265a9e55 436 && NILP (current_buffer->read_only)
9e4fd67b 437 && PT > BEGV && SYNTAX (XFASTINT (Fprevious_char ())) == Sword)
cd645247 438 {
ee8caabb 439 int modiff = MODIFF;
e57640c0
RS
440 Lisp_Object sym;
441
442 sym = Fexpand_abbrev ();
443
c87dbfd0 444 /* If we expanded an abbrev which has a hook,
9317a902 445 and the hook has a non-nil `no-self-insert' property,
e57640c0 446 return right away--don't really self-insert. */
9317a902
RS
447 if (! NILP (sym) && ! NILP (XSYMBOL (sym)->function)
448 && SYMBOLP (XSYMBOL (sym)->function))
e57640c0
RS
449 {
450 Lisp_Object prop;
9317a902 451 prop = Fget (XSYMBOL (sym)->function, intern ("no-self-insert"));
e57640c0 452 if (! NILP (prop))
6787d111 453 return 1;
e57640c0
RS
454 }
455
ee8caabb 456 if (MODIFF != modiff)
aa52fef9 457 hairy = 2;
cd645247 458 }
e744155a 459
049749e6 460 if (chars_to_delete)
e744155a 461 {
f34206b4 462 string = make_string_from_bytes (str, 1, len);
e744155a
RS
463 if (spaces_to_insert)
464 {
465 tem = Fmake_string (make_number (spaces_to_insert),
466 make_number (' '));
467 string = concat2 (tem, string);
468 }
469
5f65b1b4 470 replace_range (PT, PT + chars_to_delete, string, 1, 1, 1);
1bf95511 471 Fforward_char (make_number (1 + spaces_to_insert));
e744155a
RS
472 }
473 else
474 insert_and_inherit (str, len);
475
01428933
KH
476 if ((CHAR_TABLE_P (Vauto_fill_chars)
477 ? !NILP (CHAR_TABLE_REF (Vauto_fill_chars, c))
478 : (c == ' ' || c == '\n'))
cd645247 479 && !noautofill
3de15b7a 480 && !NILP (current_buffer->auto_fill_function))
cd645247 481 {
76bb6dbb
KH
482 Lisp_Object tem;
483
9e4fd67b 484 if (c == '\n')
049749e6
RS
485 /* After inserting a newline, move to previous line and fill
486 that. Must have the newline in place already so filling and
487 justification, if any, know where the end is going to be. */
488 SET_PT_BOTH (PT - 1, PT_BYTE - 1);
76bb6dbb 489 tem = call0 (current_buffer->auto_fill_function);
9e4fd67b 490 if (c == '\n')
049749e6 491 SET_PT_BOTH (PT + 1, PT_BYTE + 1);
76bb6dbb
KH
492 if (!NILP (tem))
493 hairy = 2;
cd645247 494 }
189fad68
RS
495
496 /* If previous command specified a face to use, use it. */
497 if (!NILP (Vself_insert_face)
346e0c2d 498 && EQ (current_kboard->Vlast_command, Vself_insert_face_command))
189fad68 499 {
049749e6
RS
500 Fput_text_property (make_number (PT - 1), make_number (PT),
501 Qface, Vself_insert_face, Qnil);
189fad68
RS
502 Vself_insert_face = Qnil;
503 }
e744155a 504
cd645247
JB
505 synt = SYNTAX (c);
506 if ((synt == Sclose || synt == Smath)
2718dfa4
RS
507 && !NILP (Vblink_paren_function) && INTERACTIVE
508 && !noautofill)
cd645247
JB
509 {
510 call0 (Vblink_paren_function);
aa52fef9 511 hairy = 2;
cd645247
JB
512 }
513 return hairy;
514}
515\f
516/* module initialization */
517
dfcf069d 518void
cd645247
JB
519syms_of_cmds ()
520{
521 Qkill_backward_chars = intern ("kill-backward-chars");
522 staticpro (&Qkill_backward_chars);
523
524 Qkill_forward_chars = intern ("kill-forward-chars");
525 staticpro (&Qkill_forward_chars);
526
6bbb0d4a
JB
527 Qoverwrite_mode_binary = intern ("overwrite-mode-binary");
528 staticpro (&Qoverwrite_mode_binary);
e686c647 529
189fad68
RS
530 DEFVAR_LISP ("self-insert-face", &Vself_insert_face,
531 "If non-nil, set the face of the next self-inserting character to this.\n\
532See also `self-insert-face-command'.");
533 Vself_insert_face = Qnil;
534
535 DEFVAR_LISP ("self-insert-face-command", &Vself_insert_face_command,
536 "This is the command that set up `self-insert-face'.\n\
537If `last-command' does not equal this value, we ignore `self-insert-face'.");
538 Vself_insert_face_command = Qnil;
539
cd645247
JB
540 DEFVAR_LISP ("blink-paren-function", &Vblink_paren_function,
541 "Function called, if non-nil, whenever a close parenthesis is inserted.\n\
542More precisely, a char with closeparen syntax is self-inserted.");
543 Vblink_paren_function = Qnil;
544
9e4fd67b 545 defsubr (&Sforward_point);
cd645247
JB
546 defsubr (&Sforward_char);
547 defsubr (&Sbackward_char);
548 defsubr (&Sforward_line);
549 defsubr (&Sbeginning_of_line);
550 defsubr (&Send_of_line);
551
552 defsubr (&Sdelete_char);
553 defsubr (&Sdelete_backward_char);
554
555 defsubr (&Sself_insert_command);
cd645247
JB
556}
557
dfcf069d 558void
cd645247
JB
559keys_of_cmds ()
560{
561 int n;
562
cbf65115 563 initial_define_key (global_map, Ctl ('I'), "self-insert-command");
cd645247
JB
564 for (n = 040; n < 0177; n++)
565 initial_define_key (global_map, n, "self-insert-command");
cf9cdc11
RS
566#ifdef MSDOS
567 for (n = 0200; n < 0240; n++)
568 initial_define_key (global_map, n, "self-insert-command");
569#endif
94748cb9 570 for (n = 0240; n < 0400; n++)
eb46da6a 571 initial_define_key (global_map, n, "self-insert-command");
cd645247
JB
572
573 initial_define_key (global_map, Ctl ('A'), "beginning-of-line");
574 initial_define_key (global_map, Ctl ('B'), "backward-char");
575 initial_define_key (global_map, Ctl ('D'), "delete-char");
576 initial_define_key (global_map, Ctl ('E'), "end-of-line");
577 initial_define_key (global_map, Ctl ('F'), "forward-char");
578 initial_define_key (global_map, 0177, "delete-backward-char");
579}