Mercurial > emacs
annotate src/cmds.c @ 109881:3db1493a6f89
New post-self-insert-hook.
* src/cmds.c (Vself_insert_face, Vself_insert_face_command): Remove.
(Qpost_self_insert_hook, Vpost_self_insert_hook): New vars.
(internal_self_insert): Run post-self-insert-hook rather than handle
self-insert-face.
(syms_of_cmds): Initialize the new vars.
* lisp/facemenu.el (facemenu-self-insert-data): New var.
(facemenu-post-self-insert-function, facemenu-set-self-insert-face): New funs.
(facemenu-add-face): Use them.
| author | Stefan Monnier <monnier@iro.umontreal.ca> |
|---|---|
| date | Thu, 19 Aug 2010 17:43:45 +0200 |
| parents | dbc0119ac80e |
| children | 8102180db0fb |
| rev | line source |
|---|---|
| 239 | 1 /* Simple built-in editing commands. |
|
64770
a0d1312ede66
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64084
diff
changeset
|
2 Copyright (C) 1985, 1993, 1994, 1995, 1996, 1997, 1998, 2001, 2002, |
| 106815 | 3 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 |
| 79759 | 4 Free Software Foundation, Inc. |
| 239 | 5 |
| 6 This file is part of GNU Emacs. | |
| 7 | |
|
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93545
diff
changeset
|
8 GNU Emacs is free software: you can redistribute it and/or modify |
| 239 | 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:
93545
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:
93545
diff
changeset
|
11 (at your option) any later version. |
| 239 | 12 |
| 13 GNU Emacs is distributed in the hope that it will be useful, | |
| 14 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 16 GNU General Public License for more details. | |
| 17 | |
| 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:
93545
diff
changeset
|
19 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
| 239 | 20 |
| 21 | |
|
4696
1fc792473491
Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents:
4561
diff
changeset
|
22 #include <config.h> |
|
105669
68dd71358159
* alloc.c: Do not define struct catchtag.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105661
diff
changeset
|
23 #include <setjmp.h> |
| 239 | 24 #include "lisp.h" |
| 25 #include "commands.h" | |
| 26 #include "buffer.h" | |
|
88351
aac41b50c875
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
41001
diff
changeset
|
27 #include "character.h" |
| 239 | 28 #include "syntax.h" |
| 8755 | 29 #include "window.h" |
|
12163
4a83c7459b52
(internal_self_insert): Make last_command be kboard-local.
Karl Heuer <kwzh@gnu.org>
parents:
11235
diff
changeset
|
30 #include "keyboard.h" |
|
39748
42b7a798ff79
Include keymap.h.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31182
diff
changeset
|
31 #include "keymap.h" |
| 21514 | 32 #include "dispextern.h" |
|
106511
1905fc4b8a80
* cmds.c: Include "frame.h".
Andreas Schwab <schwab@linux-m68k.org>
parents:
106177
diff
changeset
|
33 #include "frame.h" |
| 239 | 34 |
| 35 Lisp_Object Qkill_forward_chars, Qkill_backward_chars, Vblink_paren_function; | |
| 36 | |
|
2214
e5928bec8d5d
* cmds.c (overwrite_binary_mode): Deleted; this implements the
Jim Blandy <jimb@redhat.com>
parents:
2159
diff
changeset
|
37 /* A possible value for a buffer's overwrite-mode variable. */ |
|
e5928bec8d5d
* cmds.c (overwrite_binary_mode): Deleted; this implements the
Jim Blandy <jimb@redhat.com>
parents:
2159
diff
changeset
|
38 Lisp_Object Qoverwrite_mode_binary; |
|
e5928bec8d5d
* cmds.c (overwrite_binary_mode): Deleted; this implements the
Jim Blandy <jimb@redhat.com>
parents:
2159
diff
changeset
|
39 |
|
109509
4b7ca75642a8
Make internal_self_insert static
Andreas Schwab <schwab@linux-m68k.org>
parents:
109179
diff
changeset
|
40 static int internal_self_insert (int, int); |
| 239 | 41 |
| 17026 | 42 DEFUN ("forward-point", Fforward_point, Sforward_point, 1, 1, 0, |
|
41001
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
43 doc: /* Return buffer position N characters after (before if N negative) point. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
44 (Lisp_Object n) |
| 17026 | 45 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
46 CHECK_NUMBER (n); |
| 17026 | 47 |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
48 return make_number (PT + XINT (n)); |
| 17026 | 49 } |
| 50 | |
|
93545
63d60f1f216a
(Fforward_char, Fbackward_char, Fforward_line)
Chong Yidong <cyd@stupidchicken.com>
parents:
91327
diff
changeset
|
51 DEFUN ("forward-char", Fforward_char, Sforward_char, 0, 1, "^p", |
|
108596
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
52 doc: /* Move point N characters forward (backward if N is negative). |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
53 On reaching end or beginning of buffer, stop and signal error. |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
54 |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
55 Depending on the bidirectional context, the movement may be to the |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
56 right or to the left on the screen. This is in contrast with |
|
108895
c4f9f87f04a2
* cmds.c (Fforward_char, Fbackward_char): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
108756
diff
changeset
|
57 \\[right-char], which see. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
58 (Lisp_Object n) |
| 239 | 59 { |
|
14065
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
60 if (NILP (n)) |
|
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
61 XSETFASTINT (n, 1); |
| 239 | 62 else |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
63 CHECK_NUMBER (n); |
| 239 | 64 |
|
14065
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
65 /* This used to just set point to point + XINT (n), and then check |
|
2777
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
66 to see if it was within boundaries. But now that SET_PT can |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
67 potentially do a lot of stuff (calling entering and exiting |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
68 hooks, etcetera), that's not a good approach. So we validate the |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
69 proposed position, then set point. */ |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
70 { |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
71 int new_point = PT + XINT (n); |
|
2777
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
72 |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
73 if (new_point < BEGV) |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
74 { |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
75 SET_PT (BEGV); |
|
71971
a0c56d32ce9f
(Fforward_char, Fdelete_char): Use xsignal0.
Kim F. Storm <storm@cua.dk>
parents:
68839
diff
changeset
|
76 xsignal0 (Qbeginning_of_buffer); |
|
2777
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
77 } |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
78 if (new_point > ZV) |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
79 { |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
80 SET_PT (ZV); |
|
71971
a0c56d32ce9f
(Fforward_char, Fdelete_char): Use xsignal0.
Kim F. Storm <storm@cua.dk>
parents:
68839
diff
changeset
|
81 xsignal0 (Qend_of_buffer); |
|
2777
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
82 } |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
83 |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
84 SET_PT (new_point); |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
85 } |
|
40e00789f1c1
* cmds.c (Fforward_char): Check proposed new position, and then
Jim Blandy <jimb@redhat.com>
parents:
2214
diff
changeset
|
86 |
| 239 | 87 return Qnil; |
| 88 } | |
| 89 | |
|
93545
63d60f1f216a
(Fforward_char, Fbackward_char, Fforward_line)
Chong Yidong <cyd@stupidchicken.com>
parents:
91327
diff
changeset
|
90 DEFUN ("backward-char", Fbackward_char, Sbackward_char, 0, 1, "^p", |
|
108596
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
91 doc: /* Move point N characters backward (forward if N is negative). |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
92 On attempt to pass beginning or end of buffer, stop and signal error. |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
93 |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
94 Depending on the bidirectional context, the movement may be to the |
|
cd5442b2826b
Implement bidi-sensitive movement with arrow keys.
Eli Zaretskii <eliz@gnu.org>
parents:
107713
diff
changeset
|
95 right or to the left on the screen. This is in contrast with |
|
108895
c4f9f87f04a2
* cmds.c (Fforward_char, Fbackward_char): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
108756
diff
changeset
|
96 \\[left-char], which see. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
97 (Lisp_Object n) |
| 239 | 98 { |
|
14065
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
99 if (NILP (n)) |
|
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
100 XSETFASTINT (n, 1); |
| 239 | 101 else |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
102 CHECK_NUMBER (n); |
| 239 | 103 |
|
14065
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
104 XSETINT (n, - XINT (n)); |
|
60600bcfe5f1
(Fforward_line, Fbeginning_of_line, Fend_of_line, Fdelete_char,
Erik Naggum <erik@naggum.no>
parents:
13825
diff
changeset
|
105 return Fforward_char (n); |
| 239 | 106 } |
| 107 | |
|
93545
63d60f1f216a
(Fforward_char, Fbackward_char, Fforward_line)
Chong Yidong <cyd@stupidchicken.com>
parents:
91327
diff
changeset
|
108 DEFUN ("forward-line", Fforward_line, Sforward_line, 0, 1, "^p", |
|
41001
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
109 doc: /* Move N lines forward (backward if N is negative). |
|
109684
dbc0119ac80e
Make some doc strings bidi-friendly.
Eli Zaretskii <eliz@gnu.org>
parents:
109573
diff
changeset
|
110 Precisely, if point is on line I, move to the start of line I + N |
|
dbc0119ac80e
Make some doc strings bidi-friendly.
Eli Zaretskii <eliz@gnu.org>
parents:
109573
diff
changeset
|
111 \("start of line" in the logical order). |
|
41001
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
112 If there isn't room, go as far as possible (no error). |
|
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
113 Returns the count of lines left to move. If moving forward, |
|
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
114 that is N - number of lines moved; if backward, N + number moved. |
|
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
115 With positive N, a non-empty line at the end counts as one line |
|
108895
c4f9f87f04a2
* cmds.c (Fforward_char, Fbackward_char): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
108756
diff
changeset
|
116 successfully moved (for the return value). */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
117 (Lisp_Object n) |
| 239 | 118 { |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
119 int opoint = PT, opoint_byte = PT_BYTE; |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
120 int pos, pos_byte; |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
121 int count, shortage; |
| 239 | 122 |
| 485 | 123 if (NILP (n)) |
| 239 | 124 count = 1; |
| 125 else | |
| 126 { | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
127 CHECK_NUMBER (n); |
| 239 | 128 count = XINT (n); |
| 129 } | |
| 130 | |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
131 if (count <= 0) |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
132 shortage = scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, count - 1, 1); |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
133 else |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
134 shortage = scan_newline (PT, PT_BYTE, ZV, ZV_BYTE, count, 1); |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
135 |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
136 /* Since scan_newline does TEMP_SET_PT_BOTH, |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
137 and we want to set PT "for real", |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
138 go back to the old point and then come back here. */ |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
139 pos = PT; |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
140 pos_byte = PT_BYTE; |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
141 TEMP_SET_PT_BOTH (opoint, opoint_byte); |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
142 SET_PT_BOTH (pos, pos_byte); |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
143 |
| 239 | 144 if (shortage > 0 |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
145 && (count <= 0 |
| 647 | 146 || (ZV > BEGV |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
147 && PT != opoint |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
148 && (FETCH_BYTE (PT_BYTE - 1) != '\n')))) |
| 239 | 149 shortage--; |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
150 |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
151 return make_number (count <= 0 ? - shortage : shortage); |
| 239 | 152 } |
| 153 | |
|
93545
63d60f1f216a
(Fforward_char, Fbackward_char, Fforward_line)
Chong Yidong <cyd@stupidchicken.com>
parents:
91327
diff
changeset
|
154 DEFUN ("beginning-of-line", Fbeginning_of_line, Sbeginning_of_line, 0, 1, "^p", |
|
109684
dbc0119ac80e
Make some doc strings bidi-friendly.
Eli Zaretskii <eliz@gnu.org>
parents:
109573
diff
changeset
|
155 doc: /* Move point to beginning of current line (in the logical order). |
|
40041
9d6d2c8564b3
(Fbeginning_of_line, Fend_of_line): Clarify interaction with fields and
Miles Bader <miles@gnu.org>
parents:
39748
diff
changeset
|
156 With argument N not nil or 1, move forward N - 1 lines first. |
|
9d6d2c8564b3
(Fbeginning_of_line, Fend_of_line): Clarify interaction with fields and
Miles Bader <miles@gnu.org>
parents:
39748
diff
changeset
|
157 If point reaches the beginning or end of buffer, it stops there. |
|
9d6d2c8564b3
(Fbeginning_of_line, Fend_of_line): Clarify interaction with fields and
Miles Bader <miles@gnu.org>
parents:
39748
diff
changeset
|
158 |
|
68393
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
159 This function constrains point to the current field unless this moves |
|
108895
c4f9f87f04a2
* cmds.c (Fforward_char, Fbackward_char): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
108756
diff
changeset
|
160 point to a different line than the original, unconstrained result. |
|
c4f9f87f04a2
* cmds.c (Fforward_char, Fbackward_char): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
108756
diff
changeset
|
161 If N is nil or 1, and a front-sticky field starts at point, the point |
|
68393
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
162 does not move. To ignore field boundaries bind |
|
68391
64fbda7a8666
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
64770
diff
changeset
|
163 `inhibit-field-text-motion' to t, or use the `forward-line' function |
|
64fbda7a8666
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
64770
diff
changeset
|
164 instead. For instance, `(forward-line 0)' does the same thing as |
|
64fbda7a8666
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
64770
diff
changeset
|
165 `(beginning-of-line)', except that it ignores field boundaries. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
166 (Lisp_Object n) |
| 239 | 167 { |
| 485 | 168 if (NILP (n)) |
|
9300
84822d6ed3be
(Fforward_char, Fbackward_char, Fbeginning_of_line, Fend_of_line): Don't use
Karl Heuer <kwzh@gnu.org>
parents:
9135
diff
changeset
|
169 XSETFASTINT (n, 1); |
| 239 | 170 else |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
171 CHECK_NUMBER (n); |
| 239 | 172 |
|
25632
82ebdf9967da
(Fbeginning_of_line): Don't handle minibuffer prompt here.
Richard M. Stallman <rms@gnu.org>
parents:
25351
diff
changeset
|
173 SET_PT (XINT (Fline_beginning_position (n))); |
|
45618
21c0392ac82a
(Fdelete_backward_char, internal_self_insert): Cast
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
44754
diff
changeset
|
174 |
| 239 | 175 return Qnil; |
| 176 } | |
| 177 | |
|
93545
63d60f1f216a
(Fforward_char, Fbackward_char, Fforward_line)
Chong Yidong <cyd@stupidchicken.com>
parents:
91327
diff
changeset
|
178 DEFUN ("end-of-line", Fend_of_line, Send_of_line, 0, 1, "^p", |
|
109684
dbc0119ac80e
Make some doc strings bidi-friendly.
Eli Zaretskii <eliz@gnu.org>
parents:
109573
diff
changeset
|
179 doc: /* Move point to end of current line (in the logical order). |
|
40041
9d6d2c8564b3
(Fbeginning_of_line, Fend_of_line): Clarify interaction with fields and
Miles Bader <miles@gnu.org>
parents:
39748
diff
changeset
|
180 With argument N not nil or 1, move forward N - 1 lines first. |
|
9d6d2c8564b3
(Fbeginning_of_line, Fend_of_line): Clarify interaction with fields and
Miles Bader <miles@gnu.org>
parents:
39748
diff
changeset
|
181 If point reaches the beginning or end of buffer, it stops there. |
|
54011
b7bf96cb1f23
(Fend_of_line): Doc fix.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
182 To ignore intangibility, bind `inhibit-point-motion-hooks' to t. |
|
40041
9d6d2c8564b3
(Fbeginning_of_line, Fend_of_line): Clarify interaction with fields and
Miles Bader <miles@gnu.org>
parents:
39748
diff
changeset
|
183 |
|
68393
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
184 This function constrains point to the current field unless this moves |
|
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
185 point to a different line than the original, unconstrained result. If |
|
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
186 N is nil or 1, and a rear-sticky field ends at point, the point does |
|
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
187 not move. To ignore field boundaries bind `inhibit-field-text-motion' |
|
b5ff41ef0331
(Fbeginning_of_line, Fend_of_line): Clarify confusing doc string.
K?roly L?rentey <lorentey@elte.hu>
parents:
68391
diff
changeset
|
188 to t. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
189 (Lisp_Object n) |
| 239 | 190 { |
|
44754
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
191 int newpos; |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
192 |
| 485 | 193 if (NILP (n)) |
|
9300
84822d6ed3be
(Fforward_char, Fbackward_char, Fbeginning_of_line, Fend_of_line): Don't use
Karl Heuer <kwzh@gnu.org>
parents:
9135
diff
changeset
|
194 XSETFASTINT (n, 1); |
| 239 | 195 else |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
196 CHECK_NUMBER (n); |
| 239 | 197 |
|
44754
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
198 while (1) |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
199 { |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
200 newpos = XINT (Fline_end_position (n)); |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
201 SET_PT (newpos); |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
202 |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
203 if (PT > newpos |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
204 && FETCH_CHAR (PT - 1) == '\n') |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
205 { |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
206 /* If we skipped over a newline that follows |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
207 an invisible intangible run, |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
208 move back to the last tangible position |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
209 within the line. */ |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
210 |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
211 SET_PT (PT - 1); |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
212 break; |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
213 } |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
214 else if (PT > newpos && PT < ZV |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
215 && FETCH_CHAR (PT) != '\n') |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
216 /* If we skipped something intangible |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
217 and now we're not really at eol, |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
218 keep going. */ |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
219 n = make_number (1); |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
220 else |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
221 break; |
|
628a697e2315
(Fend_of_line): Handle intangible text in mid line.
Richard M. Stallman <rms@gnu.org>
parents:
41001
diff
changeset
|
222 } |
| 239 | 223 |
| 224 return Qnil; | |
| 225 } | |
| 226 | |
| 227 DEFUN ("delete-char", Fdelete_char, Sdelete_char, 1, 2, "p\nP", | |
|
41001
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
228 doc: /* Delete the following N characters (previous if N is negative). |
|
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
229 Optional second arg KILLFLAG non-nil means kill instead (save in kill ring). |
|
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
230 Interactively, N is the prefix arg, and KILLFLAG is set if |
|
109062
d8144fe7f3f8
* bindings.el (global-map): Bind delete and DEL, the former to
Chong Yidong <cyd@stupidchicken.com>
parents:
108895
diff
changeset
|
231 N was explicitly specified. |
|
d8144fe7f3f8
* bindings.el (global-map): Bind delete and DEL, the former to
Chong Yidong <cyd@stupidchicken.com>
parents:
108895
diff
changeset
|
232 |
|
d8144fe7f3f8
* bindings.el (global-map): Bind delete and DEL, the former to
Chong Yidong <cyd@stupidchicken.com>
parents:
108895
diff
changeset
|
233 The command `delete-forward' is preferable for interactive use. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
234 (Lisp_Object n, Lisp_Object killflag) |
| 239 | 235 { |
| 17026 | 236 int pos; |
| 237 | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
238 CHECK_NUMBER (n); |
| 239 | 239 |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
240 pos = PT + XINT (n); |
| 485 | 241 if (NILP (killflag)) |
| 239 | 242 { |
| 243 if (XINT (n) < 0) | |
| 244 { | |
| 17026 | 245 if (pos < BEGV) |
|
71971
a0c56d32ce9f
(Fforward_char, Fdelete_char): Use xsignal0.
Kim F. Storm <storm@cua.dk>
parents:
68839
diff
changeset
|
246 xsignal0 (Qbeginning_of_buffer); |
| 239 | 247 else |
| 17026 | 248 del_range (pos, PT); |
| 239 | 249 } |
| 250 else | |
| 251 { | |
| 17026 | 252 if (pos > ZV) |
|
71971
a0c56d32ce9f
(Fforward_char, Fdelete_char): Use xsignal0.
Kim F. Storm <storm@cua.dk>
parents:
68839
diff
changeset
|
253 xsignal0 (Qend_of_buffer); |
| 239 | 254 else |
| 17026 | 255 del_range (PT, pos); |
| 239 | 256 } |
| 257 } | |
| 258 else | |
| 259 { | |
| 260 call1 (Qkill_forward_chars, n); | |
| 261 } | |
| 262 return Qnil; | |
| 263 } | |
| 264 | |
|
107713
41747909cb4b
Get rid of the direct_output optimizations.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
265 static int nonundocount; |
|
104235
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
266 |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
267 /* Note that there's code in command_loop_1 which typically avoids |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
268 calling this. */ |
| 239 | 269 DEFUN ("self-insert-command", Fself_insert_command, Sself_insert_command, 1, 1, "p", |
|
41001
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
270 doc: /* Insert the character you type. |
|
104235
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
271 Whichever character you type to run this command is inserted. |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
272 Before insertion, `expand-abbrev' is executed if the inserted character does |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
273 not have word syntax and the previous character in the buffer does. |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
274 After insertion, the value of `auto-fill-function' is called if the |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
275 `auto-fill-chars' table has a non-nil value for the inserted character. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109126
diff
changeset
|
276 (Lisp_Object n) |
| 239 | 277 { |
|
106177
cb523092ddfd
* xterm.c (x_new_font):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105877
diff
changeset
|
278 int remove_boundary = 1; |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40041
diff
changeset
|
279 CHECK_NUMBER (n); |
|
104235
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
280 |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
281 if (!EQ (Vthis_command, current_kboard->Vlast_command)) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
282 nonundocount = 0; |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
283 |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
284 if (NILP (Vexecuting_kbd_macro) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
285 && !EQ (minibuf_window, selected_window)) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
286 { |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
287 if (nonundocount <= 0 || nonundocount >= 20) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
288 { |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
289 remove_boundary = 0; |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
290 nonundocount = 0; |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
291 } |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
292 nonundocount++; |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
293 } |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
294 |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
295 if (remove_boundary |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
296 && CONSP (current_buffer->undo_list) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
297 && NILP (XCAR (current_buffer->undo_list))) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
298 /* Remove the undo_boundary that was just pushed. */ |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
299 current_buffer->undo_list = XCDR (current_buffer->undo_list); |
| 239 | 300 |
| 301 /* Barf if the key that invoked this was not a character. */ | |
|
100999
58dada904f85
Update for last_command_char rename.
Glenn Morris <rgm@gnu.org>
parents:
100951
diff
changeset
|
302 if (!CHARACTERP (last_command_event)) |
| 239 | 303 bitch_at_user (); |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
304 { |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
305 int character = translate_char (Vtranslation_table_for_input, |
|
100999
58dada904f85
Update for last_command_char rename.
Glenn Morris <rgm@gnu.org>
parents:
100951
diff
changeset
|
306 XINT (last_command_event)); |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
307 if (XINT (n) >= 2 && NILP (current_buffer->overwrite_mode)) |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
308 { |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
309 XSETFASTINT (n, XFASTINT (n) - 2); |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
310 /* The first one might want to expand an abbrev. */ |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
311 internal_self_insert (character, 1); |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
312 /* The bulk of the copies of this char can be inserted simply. |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
313 We don't have to handle a user-specified face specially |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
314 because it will get inherited from the first char inserted. */ |
|
104628
8cc773a4c3d7
(Fself_insert_command): Avoid unnecessay unibyte->multibyte
Kenichi Handa <handa@m17n.org>
parents:
104235
diff
changeset
|
315 Finsert_char (make_number (character), n, Qt); |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
316 /* The last one might want to auto-fill. */ |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
317 internal_self_insert (character, 0); |
| 239 | 318 } |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
319 else |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
320 while (XINT (n) > 0) |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
321 { |
|
104235
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
322 int val; |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
323 /* Ok since old and new vals both nonneg */ |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
324 XSETFASTINT (n, XFASTINT (n) - 1); |
|
104235
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
325 val = internal_self_insert (character, XFASTINT (n) != 0); |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
326 if (val == 2) |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
327 nonundocount = 0; |
|
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
328 frame_make_pointer_invisible (); |
|
48228
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
329 } |
|
461d780ae946
(Fself_insert_command): Apply Vtranslation_table_for_input.
Dave Love <fx@gnu.org>
parents:
45618
diff
changeset
|
330 } |
| 239 | 331 |
| 332 return Qnil; | |
| 333 } | |
| 334 | |
| 17026 | 335 /* Insert character C. If NOAUTOFILL is nonzero, don't do autofill |
|
1022
f7e3bac23a06
(internal_self_insert): Ignore value of Fexpand_abbrev;
Richard M. Stallman <rms@gnu.org>
parents:
647
diff
changeset
|
336 even if it is enabled. |
|
f7e3bac23a06
(internal_self_insert): Ignore value of Fexpand_abbrev;
Richard M. Stallman <rms@gnu.org>
parents:
647
diff
changeset
|
337 |
|
f7e3bac23a06
(internal_self_insert): Ignore value of Fexpand_abbrev;
Richard M. Stallman <rms@gnu.org>
parents:
647
diff
changeset
|
338 If this insertion is suitable for direct output (completely simple), |
|
8088
a831980bb12e
(internal_self_insert): Now can return 2.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
339 return 0. A value of 1 indicates this *might* not have been simple. |
|
a831980bb12e
(internal_self_insert): Now can return 2.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
340 A value of 2 means this did things that call for an undo boundary. */ |
|
1022
f7e3bac23a06
(internal_self_insert): Ignore value of Fexpand_abbrev;
Richard M. Stallman <rms@gnu.org>
parents:
647
diff
changeset
|
341 |
|
51819
ff438bca7989
(Qexpand_abbrev): New sym.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
48228
diff
changeset
|
342 static Lisp_Object Qexpand_abbrev; |
|
109881
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
343 static Lisp_Object Qpost_self_insert_hook, Vpost_self_insert_hook; |
|
51819
ff438bca7989
(Qexpand_abbrev): New sym.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
48228
diff
changeset
|
344 |
|
109509
4b7ca75642a8
Make internal_self_insert static
Andreas Schwab <schwab@linux-m68k.org>
parents:
109179
diff
changeset
|
345 static int |
|
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109062
diff
changeset
|
346 internal_self_insert (int c, int noautofill) |
| 239 | 347 { |
| 348 int hairy = 0; | |
| 349 Lisp_Object tem; | |
| 350 register enum syntaxcode synt; | |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
351 Lisp_Object overwrite, string; |
| 17026 | 352 /* Length of multi-byte form of C. */ |
| 353 int len; | |
| 354 /* Working buffer and pointer for multi-byte form of C. */ | |
|
26845
5c3e047bbf23
(internal_self_insert): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
26390
diff
changeset
|
355 unsigned char str[MAX_MULTIBYTE_LENGTH]; |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
356 int chars_to_delete = 0; |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
357 int spaces_to_insert = 0; |
| 239 | 358 |
|
6496
e1967b6d9a5c
(internal_self_insert): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
5754
diff
changeset
|
359 overwrite = current_buffer->overwrite_mode; |
|
29378
141820271eff
(internal_self_insert): Don't check
Dave Love <fx@gnu.org>
parents:
27379
diff
changeset
|
360 if (!NILP (Vbefore_change_functions) || !NILP (Vafter_change_functions)) |
| 239 | 361 hairy = 1; |
| 362 | |
| 17026 | 363 /* At first, get multi-byte form of C in STR. */ |
| 364 if (!NILP (current_buffer->enable_multibyte_characters)) | |
|
21032
3bf522f06501
(internal_self_insert): Avoid checking enable-multibyte-characters
Kenichi Handa <handa@m17n.org>
parents:
20958
diff
changeset
|
365 { |
|
26845
5c3e047bbf23
(internal_self_insert): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
26390
diff
changeset
|
366 len = CHAR_STRING (c, str); |
|
23765
1944b3595afd
(internal_self_insert): If C has modifier bits, insert
Kenichi Handa <handa@m17n.org>
parents:
23487
diff
changeset
|
367 if (len == 1) |
|
1944b3595afd
(internal_self_insert): If C has modifier bits, insert
Kenichi Handa <handa@m17n.org>
parents:
23487
diff
changeset
|
368 /* If C has modifier bits, this makes C an appropriate |
|
1944b3595afd
(internal_self_insert): If C has modifier bits, insert
Kenichi Handa <handa@m17n.org>
parents:
23487
diff
changeset
|
369 one-byte char. */ |
|
1944b3595afd
(internal_self_insert): If C has modifier bits, insert
Kenichi Handa <handa@m17n.org>
parents:
23487
diff
changeset
|
370 c = *str; |
|
21032
3bf522f06501
(internal_self_insert): Avoid checking enable-multibyte-characters
Kenichi Handa <handa@m17n.org>
parents:
20958
diff
changeset
|
371 } |
| 17026 | 372 else |
|
22926
436499b7a769
(internal_self_insert): If enable-multibyte-characters is
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
373 { |
|
26845
5c3e047bbf23
(internal_self_insert): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
26390
diff
changeset
|
374 str[0] = (SINGLE_BYTE_CHAR_P (c) |
|
5c3e047bbf23
(internal_self_insert): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
26390
diff
changeset
|
375 ? c |
|
5c3e047bbf23
(internal_self_insert): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
26390
diff
changeset
|
376 : multibyte_char_to_unibyte (c, Qnil)); |
|
22926
436499b7a769
(internal_self_insert): If enable-multibyte-characters is
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
377 len = 1; |
|
436499b7a769
(internal_self_insert): If enable-multibyte-characters is
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
378 } |
|
2214
e5928bec8d5d
* cmds.c (overwrite_binary_mode): Deleted; this implements the
Jim Blandy <jimb@redhat.com>
parents:
2159
diff
changeset
|
379 if (!NILP (overwrite) |
| 17026 | 380 && PT < ZV) |
| 239 | 381 { |
| 17026 | 382 /* In overwrite-mode, we substitute a character at point (C2, |
| 383 hereafter) by C. For that, we delete C2 in advance. But, | |
| 384 just substituting C2 by C may move a remaining text in the | |
| 385 line to the right or to the left, which is not preferable. | |
| 386 So we insert more spaces or delete more characters in the | |
| 387 following cases: if C is narrower than C2, after deleting C2, | |
| 388 we fill columns with spaces, if C is wider than C2, we delete | |
| 389 C2 and several characters following C2. */ | |
| 390 | |
|
20615
ddb1eec37783
(internal_self_insert): Simplify handling of c2;
Richard M. Stallman <rms@gnu.org>
parents:
20541
diff
changeset
|
391 /* This is the character after point. */ |
|
ddb1eec37783
(internal_self_insert): Simplify handling of c2;
Richard M. Stallman <rms@gnu.org>
parents:
20541
diff
changeset
|
392 int c2 = FETCH_CHAR (PT_BYTE); |
|
ddb1eec37783
(internal_self_insert): Simplify handling of c2;
Richard M. Stallman <rms@gnu.org>
parents:
20541
diff
changeset
|
393 |
|
ddb1eec37783
(internal_self_insert): Simplify handling of c2;
Richard M. Stallman <rms@gnu.org>
parents:
20541
diff
changeset
|
394 /* Column the cursor should be placed at after this insertion. |
| 17026 | 395 The correct value should be calculated only when necessary. */ |
| 396 int target_clm = 0; | |
| 397 | |
|
19658
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
398 /* Overwriting in binary-mode always replaces C2 by C. |
|
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
399 Overwriting in textual-mode doesn't always do that. |
|
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
400 It inserts newlines in the usual way, |
|
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
401 and inserts any character at end of line |
|
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
402 or before a tab if it doesn't use the whole width of the tab. */ |
| 17026 | 403 if (EQ (overwrite, Qoverwrite_mode_binary) |
| 404 || (c != '\n' | |
| 405 && c2 != '\n' | |
|
19658
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
406 && ! (c2 == '\t' |
|
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
407 && XINT (current_buffer->tab_width) > 0 |
|
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
408 && XFASTINT (current_buffer->tab_width) < 20 |
|
45618
21c0392ac82a
(Fdelete_backward_char, internal_self_insert): Cast
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
44754
diff
changeset
|
409 && (target_clm = ((int) current_column () /* iftc */ |
|
24423
230bace6a57a
(internal_self_insert): Calculate column properly
Karl Heuer <kwzh@gnu.org>
parents:
23765
diff
changeset
|
410 + XINT (Fchar_width (make_number (c)))), |
|
19658
063c22255157
(internal_self_insert): Only set TARGET_CLM when C2 is tab.
Richard M. Stallman <rms@gnu.org>
parents:
18813
diff
changeset
|
411 target_clm % XFASTINT (current_buffer->tab_width))))) |
| 17026 | 412 { |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
413 int pos = PT; |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
414 int pos_byte = PT_BYTE; |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
415 |
| 17026 | 416 if (target_clm == 0) |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
417 chars_to_delete = 1; |
| 17026 | 418 else |
| 419 { | |
| 420 /* The actual cursor position after the trial of moving | |
| 421 to column TARGET_CLM. It is greater than TARGET_CLM | |
| 422 if the TARGET_CLM is middle of multi-column | |
| 423 character. In that case, the new point is set after | |
| 424 that character. */ | |
|
18748
6897bd6a1c8d
(Fdelete_backward_char): Convert Finsert_char argument to
Richard M. Stallman <rms@gnu.org>
parents:
18239
diff
changeset
|
425 int actual_clm |
|
6897bd6a1c8d
(Fdelete_backward_char): Convert Finsert_char argument to
Richard M. Stallman <rms@gnu.org>
parents:
18239
diff
changeset
|
426 = XFASTINT (Fmove_to_column (make_number (target_clm), Qnil)); |
| 17026 | 427 |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
428 chars_to_delete = PT - pos; |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
429 |
| 17026 | 430 if (actual_clm > target_clm) |
| 431 { | |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
432 /* We will delete too many columns. Let's fill columns |
| 17026 | 433 by spaces so that the remaining text won't move. */ |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
434 spaces_to_insert = actual_clm - target_clm; |
| 17026 | 435 } |
| 436 } | |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
437 SET_PT_BOTH (pos, pos_byte); |
| 17026 | 438 hairy = 2; |
| 439 } | |
|
8088
a831980bb12e
(internal_self_insert): Now can return 2.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
440 hairy = 2; |
| 239 | 441 } |
|
89057
08f4bdc64a89
(internal_self_insert): In a multibyte buffer, insert C
Kenichi Handa <handa@m17n.org>
parents:
88823
diff
changeset
|
442 |
|
08f4bdc64a89
(internal_self_insert): In a multibyte buffer, insert C
Kenichi Handa <handa@m17n.org>
parents:
88823
diff
changeset
|
443 synt = SYNTAX (c); |
|
08f4bdc64a89
(internal_self_insert): In a multibyte buffer, insert C
Kenichi Handa <handa@m17n.org>
parents:
88823
diff
changeset
|
444 |
| 485 | 445 if (!NILP (current_buffer->abbrev_mode) |
|
89057
08f4bdc64a89
(internal_self_insert): In a multibyte buffer, insert C
Kenichi Handa <handa@m17n.org>
parents:
88823
diff
changeset
|
446 && synt != Sword |
| 485 | 447 && NILP (current_buffer->read_only) |
|
89057
08f4bdc64a89
(internal_self_insert): In a multibyte buffer, insert C
Kenichi Handa <handa@m17n.org>
parents:
88823
diff
changeset
|
448 && PT > BEGV |
|
109881
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
449 && (SYNTAX (!NILP (current_buffer->enable_multibyte_characters) |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
450 ? XFASTINT (Fprevious_char ()) |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
451 : UNIBYTE_TO_CHAR (XFASTINT (Fprevious_char ()))) |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
452 == Sword)) |
| 239 | 453 { |
|
1098
79f020f34683
(internal_self_insert): Assume Fexpand_abbrev expanded
Richard M. Stallman <rms@gnu.org>
parents:
1022
diff
changeset
|
454 int modiff = MODIFF; |
|
16748
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
455 Lisp_Object sym; |
|
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
456 |
|
51819
ff438bca7989
(Qexpand_abbrev): New sym.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
48228
diff
changeset
|
457 sym = call0 (Qexpand_abbrev); |
|
16748
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
458 |
| 27379 | 459 /* If we expanded an abbrev which has a hook, |
|
16809
c378600f005d
(internal_self_insert): Check the property
Richard M. Stallman <rms@gnu.org>
parents:
16748
diff
changeset
|
460 and the hook has a non-nil `no-self-insert' property, |
|
16748
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
461 return right away--don't really self-insert. */ |
|
103875
82a4881dbc9d
(internal_self_insert): Check sym by SYMBOLP before
Kenichi Handa <handa@m17n.org>
parents:
100999
diff
changeset
|
462 if (SYMBOLP (sym) && ! NILP (sym) && ! NILP (XSYMBOL (sym)->function) |
|
16809
c378600f005d
(internal_self_insert): Check the property
Richard M. Stallman <rms@gnu.org>
parents:
16748
diff
changeset
|
463 && SYMBOLP (XSYMBOL (sym)->function)) |
|
16748
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
464 { |
|
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
465 Lisp_Object prop; |
|
16809
c378600f005d
(internal_self_insert): Check the property
Richard M. Stallman <rms@gnu.org>
parents:
16748
diff
changeset
|
466 prop = Fget (XSYMBOL (sym)->function, intern ("no-self-insert")); |
|
16748
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
467 if (! NILP (prop)) |
|
17376
aef6095be65c
(internal_self_insert): Fix return value.
Karl Heuer <kwzh@gnu.org>
parents:
17026
diff
changeset
|
468 return 1; |
|
16748
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
469 } |
|
64f315c0e3f4
(internal_self_insert): If the abbrev has no expansion,
Richard M. Stallman <rms@gnu.org>
parents:
16657
diff
changeset
|
470 |
|
1098
79f020f34683
(internal_self_insert): Assume Fexpand_abbrev expanded
Richard M. Stallman <rms@gnu.org>
parents:
1022
diff
changeset
|
471 if (MODIFF != modiff) |
|
8088
a831980bb12e
(internal_self_insert): Now can return 2.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
472 hairy = 2; |
| 239 | 473 } |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
474 |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
475 if (chars_to_delete) |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
476 { |
|
21254
d25a091700e5
(internal_self_insert): Use make_string_from_bytes.
Richard M. Stallman <rms@gnu.org>
parents:
21238
diff
changeset
|
477 string = make_string_from_bytes (str, 1, len); |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
478 if (spaces_to_insert) |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
479 { |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
480 tem = Fmake_string (make_number (spaces_to_insert), |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
481 make_number (' ')); |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
482 string = concat2 (tem, string); |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
483 } |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
484 |
|
23062
fec0e9653480
(internal_self_insert): Pass 1 as NOMARKERS to replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
22926
diff
changeset
|
485 replace_range (PT, PT + chars_to_delete, string, 1, 1, 1); |
|
21149
43ed5912d7e0
(internal_self_insert): Call Fforward_buffer to advance
Richard M. Stallman <rms@gnu.org>
parents:
21032
diff
changeset
|
486 Fforward_char (make_number (1 + spaces_to_insert)); |
|
18813
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
487 } |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
488 else |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
489 insert_and_inherit (str, len); |
|
498c1590b4a8
(internal_self_insert): When overwriting, use replace_range.
Richard M. Stallman <rms@gnu.org>
parents:
18748
diff
changeset
|
490 |
|
23487
6bed0cb78b71
(internal_self_insert): Check Vauto_fill_chars.
Kenichi Handa <handa@m17n.org>
parents:
23062
diff
changeset
|
491 if ((CHAR_TABLE_P (Vauto_fill_chars) |
|
6bed0cb78b71
(internal_self_insert): Check Vauto_fill_chars.
Kenichi Handa <handa@m17n.org>
parents:
23062
diff
changeset
|
492 ? !NILP (CHAR_TABLE_REF (Vauto_fill_chars, c)) |
|
6bed0cb78b71
(internal_self_insert): Check Vauto_fill_chars.
Kenichi Handa <handa@m17n.org>
parents:
23062
diff
changeset
|
493 : (c == ' ' || c == '\n')) |
| 239 | 494 && !noautofill |
|
10474
caf4440e63e8
(internal_self_insert): Don't test current_column
Richard M. Stallman <rms@gnu.org>
parents:
10425
diff
changeset
|
495 && !NILP (current_buffer->auto_fill_function)) |
| 239 | 496 { |
|
15262
b455f3f77823
(internal_self_insert): Don't return 2 for auto-fill
Karl Heuer <kwzh@gnu.org>
parents:
14436
diff
changeset
|
497 Lisp_Object tem; |
|
b455f3f77823
(internal_self_insert): Don't return 2 for auto-fill
Karl Heuer <kwzh@gnu.org>
parents:
14436
diff
changeset
|
498 |
| 17026 | 499 if (c == '\n') |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
500 /* After inserting a newline, move to previous line and fill |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
501 that. Must have the newline in place already so filling and |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
502 justification, if any, know where the end is going to be. */ |
|
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
503 SET_PT_BOTH (PT - 1, PT_BYTE - 1); |
|
15262
b455f3f77823
(internal_self_insert): Don't return 2 for auto-fill
Karl Heuer <kwzh@gnu.org>
parents:
14436
diff
changeset
|
504 tem = call0 (current_buffer->auto_fill_function); |
|
68839
14ada287f3fd
(internal_self_insert): Handle weird auto-fill-function.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
505 /* Test PT < ZV in case the auto-fill-function is strange. */ |
|
14ada287f3fd
(internal_self_insert): Handle weird auto-fill-function.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
506 if (c == '\n' && PT < ZV) |
|
20541
0cd7f6f42138
(forward_point): Function deleted.
Richard M. Stallman <rms@gnu.org>
parents:
19658
diff
changeset
|
507 SET_PT_BOTH (PT + 1, PT_BYTE + 1); |
|
15262
b455f3f77823
(internal_self_insert): Don't return 2 for auto-fill
Karl Heuer <kwzh@gnu.org>
parents:
14436
diff
changeset
|
508 if (!NILP (tem)) |
|
b455f3f77823
(internal_self_insert): Don't return 2 for auto-fill
Karl Heuer <kwzh@gnu.org>
parents:
14436
diff
changeset
|
509 hairy = 2; |
| 239 | 510 } |
|
10729
fb4f688fc2cf
(Vself_insert_face, Vself_insert_face_command): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
10474
diff
changeset
|
511 |
| 239 | 512 if ((synt == Sclose || synt == Smath) |
|
12869
2304fcfade47
(Fself_insert_command): Optimize the case with arg > 2
Richard M. Stallman <rms@gnu.org>
parents:
12163
diff
changeset
|
513 && !NILP (Vblink_paren_function) && INTERACTIVE |
|
2304fcfade47
(Fself_insert_command): Optimize the case with arg > 2
Richard M. Stallman <rms@gnu.org>
parents:
12163
diff
changeset
|
514 && !noautofill) |
| 239 | 515 { |
| 516 call0 (Vblink_paren_function); | |
|
8088
a831980bb12e
(internal_self_insert): Now can return 2.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
517 hairy = 2; |
| 239 | 518 } |
|
109881
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
519 /* Run hooks for electric keys. */ |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
520 call1 (Vrun_hooks, Qpost_self_insert_hook); |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
521 |
| 239 | 522 return hairy; |
| 523 } | |
| 524 | |
| 525 /* module initialization */ | |
| 526 | |
| 21514 | 527 void |
|
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109062
diff
changeset
|
528 syms_of_cmds (void) |
| 239 | 529 { |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
530 Qkill_backward_chars = intern_c_string ("kill-backward-chars"); |
| 239 | 531 staticpro (&Qkill_backward_chars); |
| 532 | |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
533 Qkill_forward_chars = intern_c_string ("kill-forward-chars"); |
| 239 | 534 staticpro (&Qkill_forward_chars); |
| 535 | |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
536 Qoverwrite_mode_binary = intern_c_string ("overwrite-mode-binary"); |
|
2214
e5928bec8d5d
* cmds.c (overwrite_binary_mode): Deleted; this implements the
Jim Blandy <jimb@redhat.com>
parents:
2159
diff
changeset
|
537 staticpro (&Qoverwrite_mode_binary); |
|
1948
e7b8107294b7
(syms_of_cmds): New var `overwrite-binary-mode'.
Richard M. Stallman <rms@gnu.org>
parents:
1098
diff
changeset
|
538 |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
539 Qexpand_abbrev = intern_c_string ("expand-abbrev"); |
|
51819
ff438bca7989
(Qexpand_abbrev): New sym.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
48228
diff
changeset
|
540 staticpro (&Qexpand_abbrev); |
|
ff438bca7989
(Qexpand_abbrev): New sym.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
48228
diff
changeset
|
541 |
|
109881
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
542 Qpost_self_insert_hook = intern_c_string ("post-self-insert-hook"); |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
543 staticpro (&Qpost_self_insert_hook); |
|
10729
fb4f688fc2cf
(Vself_insert_face, Vself_insert_face_command): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
10474
diff
changeset
|
544 |
|
109881
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
545 DEFVAR_LISP ("post-self-insert-hook", &Vpost_self_insert_hook, |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
546 doc: /* Hook run at the end of `self-insert-command'. |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
547 This run is run after inserting the charater. */); |
|
3db1493a6f89
New post-self-insert-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109684
diff
changeset
|
548 Vpost_self_insert_hook = Qnil; |
|
10729
fb4f688fc2cf
(Vself_insert_face, Vself_insert_face_command): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
10474
diff
changeset
|
549 |
| 239 | 550 DEFVAR_LISP ("blink-paren-function", &Vblink_paren_function, |
|
41001
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
551 doc: /* Function called, if non-nil, whenever a close parenthesis is inserted. |
|
a17c8b15ef1b
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
552 More precisely, a char with closeparen syntax is self-inserted. */); |
| 239 | 553 Vblink_paren_function = Qnil; |
| 554 | |
| 17026 | 555 defsubr (&Sforward_point); |
| 239 | 556 defsubr (&Sforward_char); |
| 557 defsubr (&Sbackward_char); | |
| 558 defsubr (&Sforward_line); | |
| 559 defsubr (&Sbeginning_of_line); | |
| 560 defsubr (&Send_of_line); | |
| 561 | |
| 562 defsubr (&Sdelete_char); | |
| 563 defsubr (&Sself_insert_command); | |
| 564 } | |
| 565 | |
| 21514 | 566 void |
|
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109062
diff
changeset
|
567 keys_of_cmds (void) |
| 239 | 568 { |
| 569 int n; | |
| 570 | |
|
104235
b729d024f6dc
* cmds.c (nonundocount): New global variable.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
103875
diff
changeset
|
571 nonundocount = 0; |
|
10425
f44f048966e8
(Vuse_hard_newlines): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
9884
diff
changeset
|
572 initial_define_key (global_map, Ctl ('I'), "self-insert-command"); |
| 239 | 573 for (n = 040; n < 0177; n++) |
| 574 initial_define_key (global_map, n, "self-insert-command"); | |
|
5491
3965bf498738
(keys_of_cmds) [MSDOS]: Chars 0200 to 0237 self-insert.
Richard M. Stallman <rms@gnu.org>
parents:
5054
diff
changeset
|
575 #ifdef MSDOS |
|
3965bf498738
(keys_of_cmds) [MSDOS]: Chars 0200 to 0237 self-insert.
Richard M. Stallman <rms@gnu.org>
parents:
5054
diff
changeset
|
576 for (n = 0200; n < 0240; n++) |
|
3965bf498738
(keys_of_cmds) [MSDOS]: Chars 0200 to 0237 self-insert.
Richard M. Stallman <rms@gnu.org>
parents:
5054
diff
changeset
|
577 initial_define_key (global_map, n, "self-insert-command"); |
|
3965bf498738
(keys_of_cmds) [MSDOS]: Chars 0200 to 0237 self-insert.
Richard M. Stallman <rms@gnu.org>
parents:
5054
diff
changeset
|
578 #endif |
|
5054
34c280d4e1af
(keys_of_cmds): Make 0377 self-inserting.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
579 for (n = 0240; n < 0400; n++) |
|
3223
28a9541901d7
(keys_of_cmds): Predefined 0240-0376 as self-insert.
Richard M. Stallman <rms@gnu.org>
parents:
2961
diff
changeset
|
580 initial_define_key (global_map, n, "self-insert-command"); |
| 239 | 581 |
| 582 initial_define_key (global_map, Ctl ('A'), "beginning-of-line"); | |
| 583 initial_define_key (global_map, Ctl ('B'), "backward-char"); | |
| 584 initial_define_key (global_map, Ctl ('E'), "end-of-line"); | |
| 585 initial_define_key (global_map, Ctl ('F'), "forward-char"); | |
| 586 } | |
| 52401 | 587 |
| 588 /* arch-tag: 022ba3cd-67f9-4978-9c5d-7d2b18d8644e | |
| 589 (do not change this comment) */ |
