Mercurial > emacs
annotate src/casefiddle.c @ 90049:73c7169fe4ff
(casify_region): Handle changes in byte-length
using replace_range_2 (sync to HEAD).
| author | Kenichi Handa <handa@m17n.org> |
|---|---|
| date | Mon, 06 Dec 2004 07:41:56 +0000 |
| parents | 4c90ffeb71c5 |
| children | 72cf6261961e |
| rev | line source |
|---|---|
| 118 | 1 /* GNU Emacs case conversion functions. |
| 56135 | 2 Copyright (C) 1985,94,97,98,99, 2001, 2002, 2004 |
| 3 Free Software Foundation, Inc. | |
| 118 | 4 |
| 5 This file is part of GNU Emacs. | |
| 6 | |
| 7 GNU Emacs is free software; you can redistribute it and/or modify | |
| 8 it under the terms of the GNU General Public License as published by | |
| 12244 | 9 the Free Software Foundation; either version 2, or (at your option) |
| 118 | 10 any later version. |
| 11 | |
| 12 GNU Emacs is distributed in the hope that it will be useful, | |
| 13 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 15 GNU General Public License for more details. | |
| 16 | |
| 17 You should have received a copy of the GNU General Public License | |
| 18 along with GNU Emacs; see the file COPYING. If not, write to | |
|
14186
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14063
diff
changeset
|
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
|
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14063
diff
changeset
|
20 Boston, MA 02111-1307, USA. */ |
| 118 | 21 |
| 22 | |
|
4696
1fc792473491
Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents:
2822
diff
changeset
|
23 #include <config.h> |
| 118 | 24 #include "lisp.h" |
| 25 #include "buffer.h" | |
|
88351
aac41b50c875
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
40656
diff
changeset
|
26 #include "character.h" |
| 118 | 27 #include "commands.h" |
| 28 #include "syntax.h" | |
| 26839 | 29 #include "composite.h" |
|
39748
42b7a798ff79
Include keymap.h.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
34969
diff
changeset
|
30 #include "keymap.h" |
| 118 | 31 |
| 32 enum case_action {CASE_UP, CASE_DOWN, CASE_CAPITALIZE, CASE_CAPITALIZE_UP}; | |
| 17816 | 33 |
| 34 Lisp_Object Qidentity; | |
| 118 | 35 |
| 36 Lisp_Object | |
| 37 casify_object (flag, obj) | |
| 38 enum case_action flag; | |
| 39 Lisp_Object obj; | |
| 40 { | |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
41 register int c, c1; |
| 118 | 42 register int inword = flag == CASE_DOWN; |
| 43 | |
|
15170
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
44 /* If the case table is flagged as modified, rescan it. */ |
|
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
45 if (NILP (XCHAR_TABLE (current_buffer->downcase_table)->extras[1])) |
|
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
46 Fset_case_table (current_buffer->downcase_table); |
|
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
47 |
| 118 | 48 while (1) |
| 49 { | |
|
9137
412e94c1dbf2
(casify_object): Use type test macros.
Karl Heuer <kwzh@gnu.org>
parents:
9053
diff
changeset
|
50 if (INTEGERP (obj)) |
| 118 | 51 { |
|
22506
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
52 int flagbits = (CHAR_ALT | CHAR_SUPER | CHAR_HYPER |
|
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
53 | CHAR_SHIFT | CHAR_CTL | CHAR_META); |
|
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
54 int flags = XINT (obj) & flagbits; |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
55 int multibyte = ! NILP (current_buffer->enable_multibyte_characters); |
|
22506
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
56 |
|
55743
4f33fa491183
(casify_object): Return OBJ unchanged if not real char.
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
57 /* If the character has higher bits set |
|
4f33fa491183
(casify_object): Return OBJ unchanged if not real char.
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
58 above the flags, return it unchanged. |
|
4f33fa491183
(casify_object): Return OBJ unchanged if not real char.
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
59 It is not a real character. */ |
|
4f33fa491183
(casify_object): Return OBJ unchanged if not real char.
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
60 if ((unsigned) XFASTINT (obj) > (unsigned) flagbits) |
|
4f33fa491183
(casify_object): Return OBJ unchanged if not real char.
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
61 return obj; |
|
4f33fa491183
(casify_object): Return OBJ unchanged if not real char.
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
62 |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
63 c1 = XFASTINT (obj) & ~flagbits; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
64 if (! multibyte) |
|
89056
496be2b262c6
(casify_object): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89017
diff
changeset
|
65 MAKE_CHAR_MULTIBYTE (c1); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
66 c = DOWNCASE (c1); |
|
18136
015e9e4a90ed
(casify_object): Fix bug on handling a character
Kenichi Handa <handa@m17n.org>
parents:
18005
diff
changeset
|
67 if (inword) |
|
22506
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
68 XSETFASTINT (obj, c | flags); |
|
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
69 else if (c == (XFASTINT (obj) & ~flagbits)) |
|
18136
015e9e4a90ed
(casify_object): Fix bug on handling a character
Kenichi Handa <handa@m17n.org>
parents:
18005
diff
changeset
|
70 { |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
71 if (! inword) |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
72 c = UPCASE1 (c1); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
73 if (! multibyte) |
|
89056
496be2b262c6
(casify_object): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89017
diff
changeset
|
74 MAKE_CHAR_UNIBYTE (c); |
|
22506
2107e25fa56f
(casify_object): Cope with modifier bits in character.
Karl Heuer <kwzh@gnu.org>
parents:
21514
diff
changeset
|
75 XSETFASTINT (obj, c | flags); |
|
18136
015e9e4a90ed
(casify_object): Fix bug on handling a character
Kenichi Handa <handa@m17n.org>
parents:
18005
diff
changeset
|
76 } |
| 118 | 77 return obj; |
| 78 } | |
|
20611
e351676e5044
(casify_object): Scan string by bytes and chars.
Richard M. Stallman <rms@gnu.org>
parents:
20543
diff
changeset
|
79 |
|
9137
412e94c1dbf2
(casify_object): Use type test macros.
Karl Heuer <kwzh@gnu.org>
parents:
9053
diff
changeset
|
80 if (STRINGP (obj)) |
| 118 | 81 { |
|
20611
e351676e5044
(casify_object): Scan string by bytes and chars.
Richard M. Stallman <rms@gnu.org>
parents:
20543
diff
changeset
|
82 int multibyte = STRING_MULTIBYTE (obj); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
83 int i, i_byte, len; |
| 89483 | 84 int size = SCHARS (obj); |
|
18005
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
85 |
| 118 | 86 obj = Fcopy_sequence (obj); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
87 for (i = i_byte = 0; i < size; i++, i_byte += len) |
| 118 | 88 { |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
89 if (multibyte) |
| 89483 | 90 c = STRING_CHAR_AND_LENGTH (SDATA (obj) + i_byte, 0, len); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
91 else |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
92 { |
| 89483 | 93 c = SREF (obj, i_byte); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
94 len = 1; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
95 MAKE_CHAR_MULTIBYTE (c); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
96 } |
| 89483 | 97 c1 = c; |
|
9052
6de22822cf72
(upcase_initials): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
98 if (inword && flag != CASE_CAPITALIZE_UP) |
| 118 | 99 c = DOWNCASE (c); |
|
9052
6de22822cf72
(upcase_initials): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
100 else if (!UPPERCASEP (c) |
|
6de22822cf72
(upcase_initials): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
101 && (!inword || flag != CASE_CAPITALIZE_UP)) |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
102 c = UPCASE1 (c1); |
|
9052
6de22822cf72
(upcase_initials): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
103 if ((int) flag >= (int) CASE_CAPITALIZE) |
| 89483 | 104 inword = (SYNTAX (c) == Sword); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
105 if (c != c1) |
|
18005
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
106 { |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
107 if (! multibyte) |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
108 { |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
109 MAKE_CHAR_UNIBYTE (c); |
| 89483 | 110 SSET (obj, i_byte, c); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
111 } |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
112 else if (ASCII_CHAR_P (c1) && ASCII_CHAR_P (c)) |
| 89483 | 113 SSET (obj, i_byte, c); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
114 else |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
115 { |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
116 Faset (obj, make_number (i), make_number (c)); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
117 i_byte += CHAR_BYTES (c) - len; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
118 } |
|
18005
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
119 } |
|
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
120 } |
| 118 | 121 return obj; |
| 122 } | |
|
1926
952f2a18f83d
* callint.c (Fcall_interactively): Pass the correct number of
Jim Blandy <jimb@redhat.com>
parents:
1505
diff
changeset
|
123 obj = wrong_type_argument (Qchar_or_string_p, obj); |
| 118 | 124 } |
| 125 } | |
| 126 | |
| 127 DEFUN ("upcase", Fupcase, Supcase, 1, 1, 0, | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
128 doc: /* Convert argument to upper case and return that. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
129 The argument may be a character or string. The result has the same type. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
130 The argument object is not altered--the value is a copy. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
131 See also `capitalize', `downcase' and `upcase-initials'. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
132 (obj) |
| 118 | 133 Lisp_Object obj; |
| 134 { | |
| 135 return casify_object (CASE_UP, obj); | |
| 136 } | |
| 137 | |
| 138 DEFUN ("downcase", Fdowncase, Sdowncase, 1, 1, 0, | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
139 doc: /* Convert argument to lower case and return that. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
140 The argument may be a character or string. The result has the same type. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
141 The argument object is not altered--the value is a copy. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
142 (obj) |
| 118 | 143 Lisp_Object obj; |
| 144 { | |
| 145 return casify_object (CASE_DOWN, obj); | |
| 146 } | |
| 147 | |
| 148 DEFUN ("capitalize", Fcapitalize, Scapitalize, 1, 1, 0, | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
149 doc: /* Convert argument to capitalized form and return that. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
150 This means that each word's first character is upper case |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
151 and the rest is lower case. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
152 The argument may be a character or string. The result has the same type. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
153 The argument object is not altered--the value is a copy. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
154 (obj) |
| 118 | 155 Lisp_Object obj; |
| 156 { | |
| 157 return casify_object (CASE_CAPITALIZE, obj); | |
| 158 } | |
|
9052
6de22822cf72
(upcase_initials): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
159 |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
160 /* Like Fcapitalize but change only the initials. */ |
|
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
161 |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
162 DEFUN ("upcase-initials", Fupcase_initials, Supcase_initials, 1, 1, 0, |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
163 doc: /* Convert the initial of each word in the argument to upper case. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
164 Do not change the other letters of each word. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
165 The argument may be a character or string. The result has the same type. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
166 The argument object is not altered--the value is a copy. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
167 (obj) |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
168 Lisp_Object obj; |
|
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
169 { |
|
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
170 return casify_object (CASE_CAPITALIZE_UP, obj); |
|
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
171 } |
| 118 | 172 |
| 173 /* flag is CASE_UP, CASE_DOWN or CASE_CAPITALIZE or CASE_CAPITALIZE_UP. | |
| 174 b and e specify range of buffer to operate on. */ | |
| 175 | |
| 21514 | 176 void |
| 118 | 177 casify_region (flag, b, e) |
| 178 enum case_action flag; | |
| 179 Lisp_Object b, e; | |
| 180 { | |
| 181 register int c; | |
| 182 register int inword = flag == CASE_DOWN; | |
|
18005
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
183 register int multibyte = !NILP (current_buffer->enable_multibyte_characters); |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
184 int start, end; |
|
20543
4dbda4b7c66f
(casify_region): Scan in bytes and chars.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
185 int start_byte, end_byte; |
| 26839 | 186 int changed = 0; |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
187 int opoint = PT; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
188 int opoint_byte = PT_BYTE; |
| 118 | 189 |
| 190 if (EQ (b, e)) | |
| 191 /* Not modifying because nothing marked */ | |
| 192 return; | |
| 193 | |
|
15170
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
194 /* If the case table is flagged as modified, rescan it. */ |
|
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
195 if (NILP (XCHAR_TABLE (current_buffer->downcase_table)->extras[1])) |
|
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
196 Fset_case_table (current_buffer->downcase_table); |
|
0d698228e98c
(casify_region, casify_object):
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
197 |
| 118 | 198 validate_region (&b, &e); |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
199 start = XFASTINT (b); |
|
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
200 end = XFASTINT (e); |
|
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
201 modify_region (current_buffer, start, end); |
|
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
202 record_change (start, end - start); |
|
20543
4dbda4b7c66f
(casify_region): Scan in bytes and chars.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
203 start_byte = CHAR_TO_BYTE (start); |
|
4dbda4b7c66f
(casify_region): Scan in bytes and chars.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
204 end_byte = CHAR_TO_BYTE (end); |
| 118 | 205 |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
206 while (start < end) |
| 17816 | 207 { |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
208 int c2, len; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
209 |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
210 if (multibyte) |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
211 { |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
212 c = FETCH_MULTIBYTE_CHAR (start_byte); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
213 len = CHAR_BYTES (c); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
214 } |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
215 else |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
216 { |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
217 c = FETCH_BYTE (start_byte); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
218 MAKE_CHAR_MULTIBYTE (c); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
219 len = 1; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
220 } |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
221 c2 = c; |
|
18005
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
222 if (inword && flag != CASE_CAPITALIZE_UP) |
|
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
223 c = DOWNCASE (c); |
|
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
224 else if (!UPPERCASEP (c) |
|
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
225 && (!inword || flag != CASE_CAPITALIZE_UP)) |
|
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
226 c = UPCASE1 (c); |
|
ad95aa134d60
(casify_object): Handle multibyte characters.
Kenichi Handa <handa@m17n.org>
parents:
17816
diff
changeset
|
227 if ((int) flag >= (int) CASE_CAPITALIZE) |
| 89483 | 228 inword = ((SYNTAX (c) == Sword) && (inword || !SYNTAX_PREFIX (c))); |
| 26839 | 229 if (c != c2) |
| 17816 | 230 { |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
231 changed = 1; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
232 if (! multibyte) |
| 17816 | 233 { |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
234 MAKE_CHAR_UNIBYTE (c); |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
235 FETCH_BYTE (start_byte) = c; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
236 } |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
237 else if (ASCII_CHAR_P (c2) && ASCII_CHAR_P (c)) |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
238 FETCH_BYTE (start_byte) = c; |
|
90049
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
239 else |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
240 { |
|
90049
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
241 int tolen = CHAR_BYTES (c); |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
242 int j; |
| 26839 | 243 unsigned char str[MAX_MULTIBYTE_LENGTH]; |
| 17816 | 244 |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
245 CHAR_STRING (c, str); |
|
90049
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
246 if (len == tolen) |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
247 { |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
248 /* Length is unchanged. */ |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
249 for (j = 0; j < len; ++j) |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
250 FETCH_BYTE (start_byte + j) = str[j]; |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
251 } |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
252 else |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
253 { |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
254 /* Replace one character with the other, |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
255 keeping text properties the same. */ |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
256 replace_range_2 (start, start_byte, |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
257 start + 1, start_byte + len, |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
258 str, 1, tolen, |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
259 0); |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
260 len = tolen; |
|
73c7169fe4ff
(casify_region): Handle changes in byte-length
Kenichi Handa <handa@m17n.org>
parents:
89943
diff
changeset
|
261 } |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
262 } |
| 17816 | 263 } |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
264 start++; |
|
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
265 start_byte += len; |
| 118 | 266 } |
| 267 | |
| 89483 | 268 if (PT != opoint) |
| 269 TEMP_SET_PT_BOTH (opoint, opoint_byte); | |
| 270 | |
| 26839 | 271 if (changed) |
| 272 { | |
|
89017
6a9e0cb7368b
(casify_object): Simplified. Handle the case that
Kenichi Handa <handa@m17n.org>
parents:
88426
diff
changeset
|
273 start = XFASTINT (b); |
| 26839 | 274 signal_after_change (start, end - start, end - start); |
| 275 update_compositions (start, end, CHECK_ALL); | |
| 276 } | |
| 118 | 277 } |
| 278 | |
| 279 DEFUN ("upcase-region", Fupcase_region, Supcase_region, 2, 2, "r", | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
280 doc: /* Convert the region to upper case. In programs, wants two arguments. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
281 These arguments specify the starting and ending character numbers of |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
282 the region to operate on. When used as a command, the text between |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
283 point and the mark is operated on. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
284 See also `capitalize-region'. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
285 (beg, end) |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
286 Lisp_Object beg, end; |
| 118 | 287 { |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
288 casify_region (CASE_UP, beg, end); |
| 118 | 289 return Qnil; |
| 290 } | |
| 291 | |
| 292 DEFUN ("downcase-region", Fdowncase_region, Sdowncase_region, 2, 2, "r", | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
293 doc: /* Convert the region to lower case. In programs, wants two arguments. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
294 These arguments specify the starting and ending character numbers of |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
295 the region to operate on. When used as a command, the text between |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
296 point and the mark is operated on. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
297 (beg, end) |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
298 Lisp_Object beg, end; |
| 118 | 299 { |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
300 casify_region (CASE_DOWN, beg, end); |
| 118 | 301 return Qnil; |
| 302 } | |
| 303 | |
| 304 DEFUN ("capitalize-region", Fcapitalize_region, Scapitalize_region, 2, 2, "r", | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
305 doc: /* Convert the region to capitalized form. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
306 Capitalized form means each word's first character is upper case |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
307 and the rest of it is lower case. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
308 In programs, give two arguments, the starting and ending |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
309 character positions to operate on. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
310 (beg, end) |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
311 Lisp_Object beg, end; |
| 118 | 312 { |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
313 casify_region (CASE_CAPITALIZE, beg, end); |
| 118 | 314 return Qnil; |
| 315 } | |
| 316 | |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
317 /* Like Fcapitalize_region but change only the initials. */ |
|
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
318 |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
319 DEFUN ("upcase-initials-region", Fupcase_initials_region, |
|
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
320 Supcase_initials_region, 2, 2, "r", |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
321 doc: /* Upcase the initial of each word in the region. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
322 Subsequent letters of each word are not changed. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
323 In programs, give two arguments, the starting and ending |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
324 character positions to operate on. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
325 (beg, end) |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
326 Lisp_Object beg, end; |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
327 { |
|
14063
ef7d4117c601
(Fupcase_region, Fdowncase_region, Fcapitalize_region,
Erik Naggum <erik@naggum.no>
parents:
12244
diff
changeset
|
328 casify_region (CASE_CAPITALIZE_UP, beg, end); |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
329 return Qnil; |
|
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
330 } |
| 118 | 331 |
| 332 Lisp_Object | |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
333 operate_on_word (arg, newpoint) |
| 118 | 334 Lisp_Object arg; |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
335 int *newpoint; |
| 118 | 336 { |
|
1505
4f138b03e5ab
* casefiddle.c (operate_on_word): Declare end to be an int, not a
Jim Blandy <jimb@redhat.com>
parents:
484
diff
changeset
|
337 Lisp_Object val; |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
338 int farend; |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
339 int iarg; |
| 118 | 340 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40103
diff
changeset
|
341 CHECK_NUMBER (arg); |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
342 iarg = XINT (arg); |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15170
diff
changeset
|
343 farend = scan_words (PT, iarg); |
| 118 | 344 if (!farend) |
|
12089
f7cb17ca1815
(casify_region): Use explicit local vars for start
Karl Heuer <kwzh@gnu.org>
parents:
9299
diff
changeset
|
345 farend = iarg > 0 ? ZV : BEGV; |
| 118 | 346 |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15170
diff
changeset
|
347 *newpoint = PT > farend ? PT : farend; |
|
9299
e8c880f2723e
(casify_object, operate_on_word, Fupcase_word, Fdowncase_word,
Karl Heuer <kwzh@gnu.org>
parents:
9137
diff
changeset
|
348 XSETFASTINT (val, farend); |
| 118 | 349 |
| 350 return val; | |
| 351 } | |
| 352 | |
| 353 DEFUN ("upcase-word", Fupcase_word, Supcase_word, 1, 1, "p", | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
354 doc: /* Convert following word (or ARG words) to upper case, moving over. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
355 With negative argument, convert previous words but do not move. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
356 See also `capitalize-word'. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
357 (arg) |
| 118 | 358 Lisp_Object arg; |
| 359 { | |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
360 Lisp_Object beg, end; |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
361 int newpoint; |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15170
diff
changeset
|
362 XSETFASTINT (beg, PT); |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
363 end = operate_on_word (arg, &newpoint); |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
364 casify_region (CASE_UP, beg, end); |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
365 SET_PT (newpoint); |
| 118 | 366 return Qnil; |
| 367 } | |
| 368 | |
| 369 DEFUN ("downcase-word", Fdowncase_word, Sdowncase_word, 1, 1, "p", | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
370 doc: /* Convert following word (or ARG words) to lower case, moving over. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
371 With negative argument, convert previous words but do not move. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
372 (arg) |
| 118 | 373 Lisp_Object arg; |
| 374 { | |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
375 Lisp_Object beg, end; |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
376 int newpoint; |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15170
diff
changeset
|
377 XSETFASTINT (beg, PT); |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
378 end = operate_on_word (arg, &newpoint); |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
379 casify_region (CASE_DOWN, beg, end); |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
380 SET_PT (newpoint); |
| 118 | 381 return Qnil; |
| 382 } | |
| 383 | |
| 384 DEFUN ("capitalize-word", Fcapitalize_word, Scapitalize_word, 1, 1, "p", | |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
385 doc: /* Capitalize the following word (or ARG words), moving over. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
386 This gives the word(s) a first character in upper case |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
387 and the rest lower case. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
388 With negative argument, capitalize previous words but do not move. */) |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39748
diff
changeset
|
389 (arg) |
| 118 | 390 Lisp_Object arg; |
| 391 { | |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
392 Lisp_Object beg, end; |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
393 int newpoint; |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15170
diff
changeset
|
394 XSETFASTINT (beg, PT); |
|
6221
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
395 end = operate_on_word (arg, &newpoint); |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
396 casify_region (CASE_CAPITALIZE, beg, end); |
|
c2d29681d218
(operate_on_word): Don't move point; store in *NEWPOINT.
Richard M. Stallman <rms@gnu.org>
parents:
4696
diff
changeset
|
397 SET_PT (newpoint); |
| 118 | 398 return Qnil; |
| 399 } | |
| 400 | |
| 21514 | 401 void |
| 118 | 402 syms_of_casefiddle () |
| 403 { | |
| 17816 | 404 Qidentity = intern ("identity"); |
| 405 staticpro (&Qidentity); | |
| 118 | 406 defsubr (&Supcase); |
| 407 defsubr (&Sdowncase); | |
| 408 defsubr (&Scapitalize); | |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
409 defsubr (&Supcase_initials); |
| 118 | 410 defsubr (&Supcase_region); |
| 411 defsubr (&Sdowncase_region); | |
| 412 defsubr (&Scapitalize_region); | |
|
9053
4887fc1a2dda
(Fupcase_initials_region): New function.
Richard M. Stallman <rms@gnu.org>
parents:
9052
diff
changeset
|
413 defsubr (&Supcase_initials_region); |
| 118 | 414 defsubr (&Supcase_word); |
| 415 defsubr (&Sdowncase_word); | |
| 416 defsubr (&Scapitalize_word); | |
| 417 } | |
| 418 | |
| 21514 | 419 void |
| 118 | 420 keys_of_casefiddle () |
| 421 { | |
| 422 initial_define_key (control_x_map, Ctl('U'), "upcase-region"); | |
| 484 | 423 Fput (intern ("upcase-region"), Qdisabled, Qt); |
| 118 | 424 initial_define_key (control_x_map, Ctl('L'), "downcase-region"); |
| 484 | 425 Fput (intern ("downcase-region"), Qdisabled, Qt); |
| 426 | |
| 118 | 427 initial_define_key (meta_map, 'u', "upcase-word"); |
| 428 initial_define_key (meta_map, 'l', "downcase-word"); | |
| 429 initial_define_key (meta_map, 'c', "capitalize-word"); | |
| 430 } | |
| 52401 | 431 |
| 432 /* arch-tag: 60a73c66-5489-47e7-a81f-cead4057c526 | |
| 433 (do not change this comment) */ |
