(thing-at-point-url-at-point): Don't use current
[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;
120 int temp;
cd645247 121
265a9e55 122 if (NILP (n))
cd645247
JB
123 count = 1;
124 else
125 {
126 CHECK_NUMBER (n, 0);
127 count = XINT (n);
128 }
129
049749e6
RS
130 if (count <= 0)
131 shortage = scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, count - 1, 1);
132 else
133 shortage = scan_newline (PT, PT_BYTE, ZV, ZV_BYTE, count, 1);
134
135 /* Since scan_newline does TEMP_SET_PT_BOTH,
136 and we want to set PT "for real",
137 go back to the old point and then come back here. */
138 pos = PT;
139 pos_byte = PT_BYTE;
140 TEMP_SET_PT_BOTH (opoint, opoint_byte);
141 SET_PT_BOTH (pos, pos_byte);
142
cd645247 143 if (shortage > 0
049749e6 144 && (count <= 0
502ddf23 145 || (ZV > BEGV
049749e6
RS
146 && PT != opoint
147 && (FETCH_BYTE (PT_BYTE - 1) != '\n'))))
cd645247 148 shortage--;
049749e6
RS
149
150 return make_number (count <= 0 ? - shortage : shortage);
cd645247
JB
151}
152
153DEFUN ("beginning-of-line", Fbeginning_of_line, Sbeginning_of_line,
154 0, 1, "p",
155 "Move point to beginning of current line.\n\
72d5f589 156With argument N not nil or 1, move forward N - 1 lines first.\n\
cd645247
JB
157If scan reaches end of buffer, stop there without error.")
158 (n)
159 Lisp_Object n;
160{
265a9e55 161 if (NILP (n))
48c7cef2 162 XSETFASTINT (n, 1);
cd645247
JB
163 else
164 CHECK_NUMBER (n, 0);
165
38b294ca 166 SET_PT (XINT (Fline_beginning_position (n)));
cd645247
JB
167 return Qnil;
168}
169
170DEFUN ("end-of-line", Fend_of_line, Send_of_line,
171 0, 1, "p",
172 "Move point to end of current line.\n\
72d5f589 173With argument N not nil or 1, move forward N - 1 lines first.\n\
cd645247
JB
174If scan reaches end of buffer, stop there without error.")
175 (n)
176 Lisp_Object n;
177{
178 register int pos;
179 register int stop;
180
265a9e55 181 if (NILP (n))
48c7cef2 182 XSETFASTINT (n, 1);
cd645247
JB
183 else
184 CHECK_NUMBER (n, 0);
185
38b294ca 186 SET_PT (XINT (Fline_end_position (n)));
cd645247
JB
187
188 return Qnil;
189}
190
191DEFUN ("delete-char", Fdelete_char, Sdelete_char, 1, 2, "p\nP",
72d5f589 192 "Delete the following N characters (previous if N is negative).\n\
cd645247 193Optional second arg KILLFLAG non-nil means kill instead (save in kill ring).\n\
72d5f589
EN
194Interactively, N is the prefix arg, and KILLFLAG is set if\n\
195N was explicitly specified.")
cd645247
JB
196 (n, killflag)
197 Lisp_Object n, killflag;
198{
9e4fd67b
KH
199 int pos;
200
cd645247
JB
201 CHECK_NUMBER (n, 0);
202
049749e6 203 pos = PT + XINT (n);
265a9e55 204 if (NILP (killflag))
cd645247
JB
205 {
206 if (XINT (n) < 0)
207 {
9e4fd67b 208 if (pos < BEGV)
cd645247
JB
209 Fsignal (Qbeginning_of_buffer, Qnil);
210 else
9e4fd67b 211 del_range (pos, PT);
cd645247
JB
212 }
213 else
214 {
9e4fd67b 215 if (pos > ZV)
cd645247
JB
216 Fsignal (Qend_of_buffer, Qnil);
217 else
9e4fd67b 218 del_range (PT, pos);
cd645247
JB
219 }
220 }
221 else
222 {
223 call1 (Qkill_forward_chars, n);
224 }
225 return Qnil;
226}
227
228DEFUN ("delete-backward-char", Fdelete_backward_char, Sdelete_backward_char,
229 1, 2, "p\nP",
72d5f589 230 "Delete the previous N characters (following if N is negative).\n\
cd645247 231Optional second arg KILLFLAG non-nil means kill instead (save in kill ring).\n\
72d5f589
EN
232Interactively, N is the prefix arg, and KILLFLAG is set if\n\
233N was explicitly specified.")
cd645247
JB
234 (n, killflag)
235 Lisp_Object n, killflag;
236{
aa970069 237 Lisp_Object value;
7c983171 238 int deleted_special = 0;
ceb7e4f8 239 int pos, pos_byte, i;
aa970069 240
cd645247 241 CHECK_NUMBER (n, 0);
aa970069 242
7c983171 243 /* See if we are about to delete a tab or newline backwards. */
ceb7e4f8
KH
244 pos = PT;
245 pos_byte = PT_BYTE;
246 for (i = 0; i < XINT (n) && pos_byte > BEGV_BYTE; i++)
aa970069 247 {
9e4fd67b
KH
248 int c;
249
ceb7e4f8
KH
250 DEC_BOTH (pos, pos_byte);
251 c = FETCH_BYTE (pos_byte);
9e4fd67b 252 if (c == '\t' || c == '\n')
aa970069 253 {
7c983171 254 deleted_special = 1;
aa970069
RS
255 break;
256 }
257 }
258
aa970069
RS
259 /* In overwrite mode, back over columns while clearing them out,
260 unless at end of line. */
261 if (XINT (n) > 0
262 && ! NILP (current_buffer->overwrite_mode)
7c983171 263 && ! deleted_special
049749e6 264 && ! (PT == ZV || FETCH_BYTE (PT_BYTE) == '\n'))
aa970069 265 {
9e4fd67b
KH
266 int column = current_column ();
267
268 value = Fdelete_char (make_number (-XINT (n)), killflag);
269 i = column - current_column ();
cac55749 270 Finsert_char (make_number (' '), make_number (i), Qnil);
049749e6
RS
271 /* Whitespace chars are ASCII chars, so we can simply subtract. */
272 SET_PT_BOTH (PT - i, PT_BYTE - i);
aa970069 273 }
9e4fd67b
KH
274 else
275 value = Fdelete_char (make_number (-XINT (n)), killflag);
aa970069
RS
276
277 return value;
cd645247
JB
278}
279
280DEFUN ("self-insert-command", Fself_insert_command, Sself_insert_command, 1, 1, "p",
281 "Insert the character you type.\n\
282Whichever character you type to run this command is inserted.")
72d5f589
EN
283 (n)
284 Lisp_Object n;
cd645247 285{
a22ca1e0
RS
286 int character = XINT (last_command_char);
287
72d5f589 288 CHECK_NUMBER (n, 0);
cd645247
JB
289
290 /* Barf if the key that invoked this was not a character. */
ed76f667 291 if (!INTEGERP (last_command_char))
cd645247 292 bitch_at_user ();
72d5f589 293 else if (XINT (n) >= 2 && NILP (current_buffer->overwrite_mode))
2718dfa4 294 {
a22ca1e0
RS
295 int modified_char = character;
296 /* Add the offset to the character, for Finsert_char.
297 We pass internal_self_insert the unmodified character
298 because it itself does this offsetting. */
49bc32b0
RS
299 if (! NILP (current_buffer->enable_multibyte_characters))
300 modified_char = unibyte_char_to_multibyte (modified_char);
a22ca1e0 301
72d5f589 302 XSETFASTINT (n, XFASTINT (n) - 2);
2718dfa4 303 /* The first one might want to expand an abbrev. */
a22ca1e0 304 internal_self_insert (character, 1);
2718dfa4
RS
305 /* The bulk of the copies of this char can be inserted simply.
306 We don't have to handle a user-specified face specially
307 because it will get inherited from the first char inserted. */
a22ca1e0 308 Finsert_char (make_number (modified_char), n, Qt);
2718dfa4 309 /* The last one might want to auto-fill. */
a22ca1e0 310 internal_self_insert (character, 0);
2718dfa4 311 }
cd645247 312 else
72d5f589 313 while (XINT (n) > 0)
cd645247 314 {
f58dd69b 315 /* Ok since old and new vals both nonneg */
72d5f589 316 XSETFASTINT (n, XFASTINT (n) - 1);
a22ca1e0 317 internal_self_insert (character, XFASTINT (n) != 0);
cd645247
JB
318 }
319
320 return Qnil;
321}
322
9e4fd67b 323/* Insert character C. If NOAUTOFILL is nonzero, don't do autofill
4c6e656f
RS
324 even if it is enabled.
325
326 If this insertion is suitable for direct output (completely simple),
aa52fef9
RS
327 return 0. A value of 1 indicates this *might* not have been simple.
328 A value of 2 means this did things that call for an undo boundary. */
4c6e656f 329
dfcf069d 330int
9e4fd67b
KH
331internal_self_insert (c, noautofill)
332 int c;
cd645247
JB
333 int noautofill;
334{
335 extern Lisp_Object Fexpand_abbrev ();
336 int hairy = 0;
337 Lisp_Object tem;
338 register enum syntaxcode synt;
e744155a 339 Lisp_Object overwrite, string;
9e4fd67b
KH
340 /* Length of multi-byte form of C. */
341 int len;
342 /* Working buffer and pointer for multi-byte form of C. */
343 unsigned char workbuf[4], *str;
049749e6 344 int chars_to_delete = 0;
e744155a 345 int spaces_to_insert = 0;
cd645247 346
e7aacab7 347 overwrite = current_buffer->overwrite_mode;
166a4263
RS
348 if (!NILP (Vbefore_change_function) || !NILP (Vafter_change_function)
349 || !NILP (Vbefore_change_functions) || !NILP (Vafter_change_functions))
cd645247
JB
350 hairy = 1;
351
9e4fd67b
KH
352 /* At first, get multi-byte form of C in STR. */
353 if (!NILP (current_buffer->enable_multibyte_characters))
b9859007
KH
354 {
355 c = unibyte_char_to_multibyte (c);
356 len = CHAR_STRING (c, workbuf, str);
357 }
9e4fd67b 358 else
38b62842
KH
359 {
360 workbuf[0] = (SINGLE_BYTE_CHAR_P (c)
361 ? c
362 : multibyte_char_to_unibyte (c, Qnil));
363 str = workbuf;
364 len = 1;
365 }
6bbb0d4a 366 if (!NILP (overwrite)
9e4fd67b 367 && PT < ZV)
cd645247 368 {
9e4fd67b
KH
369 /* In overwrite-mode, we substitute a character at point (C2,
370 hereafter) by C. For that, we delete C2 in advance. But,
371 just substituting C2 by C may move a remaining text in the
372 line to the right or to the left, which is not preferable.
373 So we insert more spaces or delete more characters in the
374 following cases: if C is narrower than C2, after deleting C2,
375 we fill columns with spaces, if C is wider than C2, we delete
376 C2 and several characters following C2. */
377
216b9443
RS
378 /* This is the character after point. */
379 int c2 = FETCH_CHAR (PT_BYTE);
380
381 /* Column the cursor should be placed at after this insertion.
9e4fd67b
KH
382 The correct value should be calculated only when necessary. */
383 int target_clm = 0;
384
37c0ed09
RS
385 /* Overwriting in binary-mode always replaces C2 by C.
386 Overwriting in textual-mode doesn't always do that.
387 It inserts newlines in the usual way,
388 and inserts any character at end of line
389 or before a tab if it doesn't use the whole width of the tab. */
9e4fd67b
KH
390 if (EQ (overwrite, Qoverwrite_mode_binary)
391 || (c != '\n'
392 && c2 != '\n'
37c0ed09
RS
393 && ! (c2 == '\t'
394 && XINT (current_buffer->tab_width) > 0
395 && XFASTINT (current_buffer->tab_width) < 20
216b9443
RS
396 && (target_clm = (current_column ()
397 + XINT (Fchar_width (make_number (c2)))),
37c0ed09 398 target_clm % XFASTINT (current_buffer->tab_width)))))
9e4fd67b 399 {
e744155a 400 int pos = PT;
049749e6 401 int pos_byte = PT_BYTE;
e744155a 402
9e4fd67b 403 if (target_clm == 0)
049749e6 404 chars_to_delete = 1;
9e4fd67b
KH
405 else
406 {
9e4fd67b
KH
407 /* The actual cursor position after the trial of moving
408 to column TARGET_CLM. It is greater than TARGET_CLM
409 if the TARGET_CLM is middle of multi-column
410 character. In that case, the new point is set after
411 that character. */
cac55749
RS
412 int actual_clm
413 = XFASTINT (Fmove_to_column (make_number (target_clm), Qnil));
9e4fd67b 414
049749e6 415 chars_to_delete = PT - pos;
e744155a 416
9e4fd67b
KH
417 if (actual_clm > target_clm)
418 {
e744155a 419 /* We will delete too many columns. Let's fill columns
9e4fd67b 420 by spaces so that the remaining text won't move. */
e744155a 421 spaces_to_insert = actual_clm - target_clm;
9e4fd67b
KH
422 }
423 }
049749e6 424 SET_PT_BOTH (pos, pos_byte);
9e4fd67b
KH
425 hairy = 2;
426 }
aa52fef9 427 hairy = 2;
cd645247 428 }
265a9e55 429 if (!NILP (current_buffer->abbrev_mode)
cd645247 430 && SYNTAX (c) != Sword
265a9e55 431 && NILP (current_buffer->read_only)
9e4fd67b 432 && PT > BEGV && SYNTAX (XFASTINT (Fprevious_char ())) == Sword)
cd645247 433 {
ee8caabb 434 int modiff = MODIFF;
e57640c0
RS
435 Lisp_Object sym;
436
437 sym = Fexpand_abbrev ();
438
439 /* If we expanded an abbrev which has only a hook,
9317a902 440 and the hook has a non-nil `no-self-insert' property,
e57640c0 441 return right away--don't really self-insert. */
9317a902
RS
442 if (! NILP (sym) && ! NILP (XSYMBOL (sym)->function)
443 && SYMBOLP (XSYMBOL (sym)->function))
e57640c0
RS
444 {
445 Lisp_Object prop;
9317a902 446 prop = Fget (XSYMBOL (sym)->function, intern ("no-self-insert"));
e57640c0 447 if (! NILP (prop))
6787d111 448 return 1;
e57640c0
RS
449 }
450
ee8caabb 451 if (MODIFF != modiff)
aa52fef9 452 hairy = 2;
cd645247 453 }
e744155a 454
049749e6 455 if (chars_to_delete)
e744155a 456 {
f34206b4 457 string = make_string_from_bytes (str, 1, len);
e744155a
RS
458 if (spaces_to_insert)
459 {
460 tem = Fmake_string (make_number (spaces_to_insert),
461 make_number (' '));
462 string = concat2 (tem, string);
463 }
464
5f65b1b4 465 replace_range (PT, PT + chars_to_delete, string, 1, 1, 1);
1bf95511 466 Fforward_char (make_number (1 + spaces_to_insert));
e744155a
RS
467 }
468 else
469 insert_and_inherit (str, len);
470
01428933
KH
471 if ((CHAR_TABLE_P (Vauto_fill_chars)
472 ? !NILP (CHAR_TABLE_REF (Vauto_fill_chars, c))
473 : (c == ' ' || c == '\n'))
cd645247 474 && !noautofill
3de15b7a 475 && !NILP (current_buffer->auto_fill_function))
cd645247 476 {
76bb6dbb
KH
477 Lisp_Object tem;
478
9e4fd67b 479 if (c == '\n')
049749e6
RS
480 /* After inserting a newline, move to previous line and fill
481 that. Must have the newline in place already so filling and
482 justification, if any, know where the end is going to be. */
483 SET_PT_BOTH (PT - 1, PT_BYTE - 1);
76bb6dbb 484 tem = call0 (current_buffer->auto_fill_function);
9e4fd67b 485 if (c == '\n')
049749e6 486 SET_PT_BOTH (PT + 1, PT_BYTE + 1);
76bb6dbb
KH
487 if (!NILP (tem))
488 hairy = 2;
cd645247 489 }
189fad68 490
38d404db 491#ifdef HAVE_FACES
189fad68
RS
492 /* If previous command specified a face to use, use it. */
493 if (!NILP (Vself_insert_face)
346e0c2d 494 && EQ (current_kboard->Vlast_command, Vself_insert_face_command))
189fad68 495 {
049749e6
RS
496 Fput_text_property (make_number (PT - 1), make_number (PT),
497 Qface, Vself_insert_face, Qnil);
189fad68
RS
498 Vself_insert_face = Qnil;
499 }
38d404db 500#endif
e744155a 501
cd645247
JB
502 synt = SYNTAX (c);
503 if ((synt == Sclose || synt == Smath)
2718dfa4
RS
504 && !NILP (Vblink_paren_function) && INTERACTIVE
505 && !noautofill)
cd645247
JB
506 {
507 call0 (Vblink_paren_function);
aa52fef9 508 hairy = 2;
cd645247
JB
509 }
510 return hairy;
511}
512\f
513/* module initialization */
514
dfcf069d 515void
cd645247
JB
516syms_of_cmds ()
517{
518 Qkill_backward_chars = intern ("kill-backward-chars");
519 staticpro (&Qkill_backward_chars);
520
521 Qkill_forward_chars = intern ("kill-forward-chars");
522 staticpro (&Qkill_forward_chars);
523
6bbb0d4a
JB
524 Qoverwrite_mode_binary = intern ("overwrite-mode-binary");
525 staticpro (&Qoverwrite_mode_binary);
e686c647 526
189fad68
RS
527 DEFVAR_LISP ("self-insert-face", &Vself_insert_face,
528 "If non-nil, set the face of the next self-inserting character to this.\n\
529See also `self-insert-face-command'.");
530 Vself_insert_face = Qnil;
531
532 DEFVAR_LISP ("self-insert-face-command", &Vself_insert_face_command,
533 "This is the command that set up `self-insert-face'.\n\
534If `last-command' does not equal this value, we ignore `self-insert-face'.");
535 Vself_insert_face_command = Qnil;
536
cd645247
JB
537 DEFVAR_LISP ("blink-paren-function", &Vblink_paren_function,
538 "Function called, if non-nil, whenever a close parenthesis is inserted.\n\
539More precisely, a char with closeparen syntax is self-inserted.");
540 Vblink_paren_function = Qnil;
541
9e4fd67b 542 defsubr (&Sforward_point);
cd645247
JB
543 defsubr (&Sforward_char);
544 defsubr (&Sbackward_char);
545 defsubr (&Sforward_line);
546 defsubr (&Sbeginning_of_line);
547 defsubr (&Send_of_line);
548
549 defsubr (&Sdelete_char);
550 defsubr (&Sdelete_backward_char);
551
552 defsubr (&Sself_insert_command);
cd645247
JB
553}
554
dfcf069d 555void
cd645247
JB
556keys_of_cmds ()
557{
558 int n;
559
cbf65115 560 initial_define_key (global_map, Ctl ('I'), "self-insert-command");
cd645247
JB
561 for (n = 040; n < 0177; n++)
562 initial_define_key (global_map, n, "self-insert-command");
cf9cdc11
RS
563#ifdef MSDOS
564 for (n = 0200; n < 0240; n++)
565 initial_define_key (global_map, n, "self-insert-command");
566#endif
94748cb9 567 for (n = 0240; n < 0400; n++)
eb46da6a 568 initial_define_key (global_map, n, "self-insert-command");
cd645247
JB
569
570 initial_define_key (global_map, Ctl ('A'), "beginning-of-line");
571 initial_define_key (global_map, Ctl ('B'), "backward-char");
572 initial_define_key (global_map, Ctl ('D'), "delete-char");
573 initial_define_key (global_map, Ctl ('E'), "end-of-line");
574 initial_define_key (global_map, Ctl ('F'), "forward-char");
575 initial_define_key (global_map, 0177, "delete-backward-char");
576}