Mercurial > emacs
annotate src/coding.c @ 112007:79209520f4c4
* help-fns.el (find-lisp-object-file-name): Locate .emacs from .emacs.elc (Bug#7530).
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Tue, 21 Dec 2010 14:45:11 +0800 |
parents | a5a188ddc758 |
children | 417b1e4d63cd |
rev | line source |
---|---|
88936 | 1 /* Coding system handler (conversion, detection, etc). |
68651
3bd95f4f2941
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68567
diff
changeset
|
2 Copyright (C) 2001, 2002, 2003, 2004, 2005, |
106815 | 3 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
74605
6ee41fdd69ff
Update AIST copyright years.
Kenichi Handa <handa@m17n.org>
parents:
73995
diff
changeset
|
4 Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, |
106815 | 5 2005, 2006, 2007, 2008, 2009, 2010 |
67658 | 6 National Institute of Advanced Industrial Science and Technology (AIST) |
7 Registration Number H14PRO021 | |
89483 | 8 Copyright (C) 2003 |
88365 | 9 National Institute of Advanced Industrial Science and Technology (AIST) |
10 Registration Number H13PRO009 | |
17052 | 11 |
17071 | 12 This file is part of GNU Emacs. |
13 | |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94944
diff
changeset
|
14 GNU Emacs is free software: you can redistribute it and/or modify |
17071 | 15 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:
94944
diff
changeset
|
16 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:
94944
diff
changeset
|
17 (at your option) any later version. |
17071 | 18 |
19 GNU Emacs is distributed in the hope that it will be useful, | |
20 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
21 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
22 GNU General Public License for more details. | |
23 | |
24 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:
94944
diff
changeset
|
25 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
17052 | 26 |
27 /*** TABLE OF CONTENTS *** | |
28 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
29 0. General comments |
17052 | 30 1. Preamble |
88365 | 31 2. Emacs' internal format (emacs-utf-8) handlers |
32 3. UTF-8 handlers | |
33 4. UTF-16 handlers | |
34 5. Charset-base coding systems handlers | |
35 6. emacs-mule (old Emacs' internal format) handlers | |
36 7. ISO2022 handlers | |
37 8. Shift-JIS and BIG5 handlers | |
38 9. CCL handlers | |
39 10. C library functions | |
40 11. Emacs Lisp library functions | |
41 12. Postamble | |
17052 | 42 |
43 */ | |
44 | |
88365 | 45 /*** 0. General comments *** |
46 | |
47 | |
48 CODING SYSTEM | |
49 | |
88485 | 50 A coding system is an object for an encoding mechanism that contains |
51 information about how to convert byte sequences to character | |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
52 sequences and vice versa. When we say "decode", it means converting |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
53 a byte sequence of a specific coding system into a character |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
54 sequence that is represented by Emacs' internal coding system |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
55 `emacs-utf-8', and when we say "encode", it means converting a |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
56 character sequence of emacs-utf-8 to a byte sequence of a specific |
17835
f36ffb6f1208
Name change through the code:
Kenichi Handa <handa@m17n.org>
parents:
17725
diff
changeset
|
57 coding system. |
f36ffb6f1208
Name change through the code:
Kenichi Handa <handa@m17n.org>
parents:
17725
diff
changeset
|
58 |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
59 In Emacs Lisp, a coding system is represented by a Lisp symbol. In |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
60 C level, a coding system is represented by a vector of attributes |
88485 | 61 stored in the hash table Vcharset_hash_table. The conversion from |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
62 coding system symbol to attributes vector is done by looking up |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
63 Vcharset_hash_table by the symbol. |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
64 |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
65 Coding systems are classified into the following types depending on |
88485 | 66 the encoding mechanism. Here's a brief description of the types. |
88365 | 67 |
68 o UTF-8 | |
69 | |
70 o UTF-16 | |
71 | |
72 o Charset-base coding system | |
73 | |
74 A coding system defined by one or more (coded) character sets. | |
88485 | 75 Decoding and encoding are done by a code converter defined for each |
88365 | 76 character set. |
77 | |
88485 | 78 o Old Emacs internal format (emacs-mule) |
79 | |
80 The coding system adopted by old versions of Emacs (20 and 21). | |
88365 | 81 |
82 o ISO2022-base coding system | |
17052 | 83 |
84 The most famous coding system for multiple character sets. X's | |
88365 | 85 Compound Text, various EUCs (Extended Unix Code), and coding systems |
86 used in the Internet communication such as ISO-2022-JP are all | |
87 variants of ISO2022. | |
88 | |
89 o SJIS (or Shift-JIS or MS-Kanji-Code) | |
42104
d69c2368e549
(DECODE_COMPOSITION_END): Fixed a typo in the last
Sam Steingold <sds@gnu.org>
parents:
42103
diff
changeset
|
90 |
17052 | 91 A coding system to encode character sets: ASCII, JISX0201, and |
92 JISX0208. Widely used for PC's in Japan. Details are described in | |
88365 | 93 section 8. |
94 | |
95 o BIG5 | |
96 | |
97 A coding system to encode character sets: ASCII and Big5. Widely | |
35053 | 98 used for Chinese (mainly in Taiwan and Hong Kong). Details are |
88365 | 99 described in section 8. In this file, when we write "big5" (all |
100 lowercase), we mean the coding system, and when we write "Big5" | |
101 (capitalized), we mean the character set. | |
102 | |
103 o CCL | |
104 | |
88485 | 105 If a user wants to decode/encode text encoded in a coding system |
88365 | 106 not listed above, he can supply a decoder and an encoder for it in |
107 CCL (Code Conversion Language) programs. Emacs executes the CCL | |
108 program while decoding/encoding. | |
109 | |
110 o Raw-text | |
111 | |
88771 | 112 A coding system for text containing raw eight-bit data. Emacs |
88485 | 113 treats each byte of source text as a character (except for |
88365 | 114 end-of-line conversion). |
115 | |
116 o No-conversion | |
117 | |
118 Like raw text, but don't do end-of-line conversion. | |
119 | |
120 | |
121 END-OF-LINE FORMAT | |
122 | |
88485 | 123 How text end-of-line is encoded depends on operating system. For |
88365 | 124 instance, Unix's format is just one byte of LF (line-feed) code, |
18766 | 125 whereas DOS's format is two-byte sequence of `carriage-return' and |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
126 `line-feed' codes. MacOS's format is usually one byte of |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
127 `carriage-return'. |
17052 | 128 |
35053 | 129 Since text character encoding and end-of-line encoding are |
88365 | 130 independent, any coding system described above can take any format |
131 of end-of-line (except for no-conversion). | |
17052 | 132 |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
133 STRUCT CODING_SYSTEM |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
134 |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
135 Before using a coding system for code conversion (i.e. decoding and |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
136 encoding), we setup a structure of type `struct coding_system'. |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
137 This structure keeps various information about a specific code |
88485 | 138 conversion (e.g. the location of source and destination data). |
17052 | 139 |
140 */ | |
141 | |
88365 | 142 /* COMMON MACROS */ |
143 | |
144 | |
17052 | 145 /*** GENERAL NOTES on `detect_coding_XXX ()' functions *** |
146 | |
88365 | 147 These functions check if a byte sequence specified as a source in |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
148 CODING conforms to the format of XXX, and update the members of |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
149 DETECT_INFO. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
150 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
151 Return 1 if the byte sequence conforms to XXX, otherwise return 0. |
88365 | 152 |
153 Below is the template of these functions. */ | |
154 | |
17052 | 155 #if 0 |
88365 | 156 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
157 detect_coding_XXX (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
158 struct coding_detection_info *detect_info) |
17052 | 159 { |
90070
95879cc1ed20
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-81
Miles Bader <miles@gnu.org>
diff
changeset
|
160 const unsigned char *src = coding->source; |
95879cc1ed20
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-81
Miles Bader <miles@gnu.org>
diff
changeset
|
161 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 162 int multibytep = coding->src_multibyte; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
163 int consumed_chars = 0; |
88365 | 164 int found = 0; |
165 ...; | |
166 | |
167 while (1) | |
168 { | |
110983 | 169 /* Get one byte from the source. If the source is exhausted, jump |
88365 | 170 to no_more_source:. */ |
171 ONE_MORE_BYTE (c); | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
172 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
173 if (! __C_conforms_to_XXX___ (c)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
174 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
175 if (! __C_strongly_suggests_XXX__ (c)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
176 found = CATEGORY_MASK_XXX; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
177 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
178 /* The byte sequence is invalid for XXX. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
179 detect_info->rejected |= CATEGORY_MASK_XXX; |
88365 | 180 return 0; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
181 |
88365 | 182 no_more_source: |
110983 | 183 /* The source exhausted successfully. */ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
184 detect_info->found |= found; |
88365 | 185 return 1; |
17052 | 186 } |
187 #endif | |
188 | |
189 /*** GENERAL NOTES on `decode_coding_XXX ()' functions *** | |
190 | |
88365 | 191 These functions decode a byte sequence specified as a source by |
192 CODING. The resulting multibyte text goes to a place pointed to by | |
193 CODING->charbuf, the length of which should not exceed | |
194 CODING->charbuf_size; | |
195 | |
196 These functions set the information of original and decoded texts in | |
197 CODING->consumed, CODING->consumed_char, and CODING->charbuf_used. | |
198 They also set CODING->result to one of CODING_RESULT_XXX indicating | |
199 how the decoding is finished. | |
200 | |
201 Below is the template of these functions. */ | |
202 | |
17052 | 203 #if 0 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
204 static void |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
205 decode_coding_XXXX (struct coding_system *coding) |
17052 | 206 { |
90070
95879cc1ed20
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-81
Miles Bader <miles@gnu.org>
diff
changeset
|
207 const unsigned char *src = coding->source + coding->consumed; |
95879cc1ed20
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-81
Miles Bader <miles@gnu.org>
diff
changeset
|
208 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 209 /* SRC_BASE remembers the start position in source in each loop. |
210 The loop will be exited when there's not enough source code, or | |
211 when there's no room in CHARBUF for a decoded character. */ | |
90070
95879cc1ed20
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-81
Miles Bader <miles@gnu.org>
diff
changeset
|
212 const unsigned char *src_base; |
88365 | 213 /* A buffer to produce decoded characters. */ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
214 int *charbuf = coding->charbuf + coding->charbuf_used; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
215 int *charbuf_end = coding->charbuf + coding->charbuf_size; |
88365 | 216 int multibytep = coding->src_multibyte; |
217 | |
218 while (1) | |
219 { | |
220 src_base = src; | |
221 if (charbuf < charbuf_end) | |
222 /* No more room to produce a decoded character. */ | |
223 break; | |
224 ONE_MORE_BYTE (c); | |
225 /* Decode it. */ | |
226 } | |
227 | |
228 no_more_source: | |
229 if (src_base < src_end | |
230 && coding->mode & CODING_MODE_LAST_BLOCK) | |
231 /* If the source ends by partial bytes to construct a character, | |
232 treat them as eight-bit raw data. */ | |
233 while (src_base < src_end && charbuf < charbuf_end) | |
234 *charbuf++ = *src_base++; | |
235 /* Remember how many bytes and characters we consumed. If the | |
236 source is multibyte, the bytes and chars are not identical. */ | |
237 coding->consumed = coding->consumed_char = src_base - coding->source; | |
238 /* Remember how many characters we produced. */ | |
239 coding->charbuf_used = charbuf - coding->charbuf; | |
17052 | 240 } |
241 #endif | |
242 | |
243 /*** GENERAL NOTES on `encode_coding_XXX ()' functions *** | |
244 | |
88365 | 245 These functions encode SRC_BYTES length text at SOURCE of Emacs' |
246 internal multibyte format by CODING. The resulting byte sequence | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
247 goes to a place pointed to by DESTINATION, the length of which |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
248 should not exceed DST_BYTES. |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
249 |
88365 | 250 These functions set the information of original and encoded texts in |
251 the members produced, produced_char, consumed, and consumed_char of | |
252 the structure *CODING. They also set the member result to one of | |
253 CODING_RESULT_XXX indicating how the encoding finished. | |
254 | |
255 DST_BYTES zero means that source area and destination area are | |
256 overlapped, which means that we can produce a encoded text until it | |
257 reaches at the head of not-yet-encoded source text. | |
258 | |
259 Below is a template of these functions. */ | |
17052 | 260 #if 0 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
261 static void |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
262 encode_coding_XXX (struct coding_system *coding) |
17052 | 263 { |
88365 | 264 int multibytep = coding->dst_multibyte; |
265 int *charbuf = coding->charbuf; | |
266 int *charbuf_end = charbuf->charbuf + coding->charbuf_used; | |
267 unsigned char *dst = coding->destination + coding->produced; | |
268 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
269 unsigned char *adjusted_dst_end = dst_end - _MAX_BYTES_PRODUCED_IN_LOOP_; | |
270 int produced_chars = 0; | |
271 | |
272 for (; charbuf < charbuf_end && dst < adjusted_dst_end; charbuf++) | |
273 { | |
274 int c = *charbuf; | |
275 /* Encode C into DST, and increment DST. */ | |
276 } | |
277 label_no_more_destination: | |
278 /* How many chars and bytes we produced. */ | |
279 coding->produced_char += produced_chars; | |
280 coding->produced = dst - coding->destination; | |
17052 | 281 } |
282 #endif | |
283 | |
284 | |
285 /*** 1. Preamble ***/ | |
286 | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
287 #include <config.h> |
17052 | 288 #include <stdio.h> |
105669
68dd71358159
* alloc.c: Do not define struct catchtag.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105179
diff
changeset
|
289 #include <setjmp.h> |
17052 | 290 |
291 #include "lisp.h" | |
292 #include "buffer.h" | |
88365 | 293 #include "character.h" |
17052 | 294 #include "charset.h" |
88365 | 295 #include "ccl.h" |
26847 | 296 #include "composite.h" |
17052 | 297 #include "coding.h" |
298 #include "window.h" | |
83127
5182815e0ee1
Make terminal_coding and keyboard_coding display-local.
Karoly Lorentey <lorentey@elte.hu>
parents:
54320
diff
changeset
|
299 #include "frame.h" |
5182815e0ee1
Make terminal_coding and keyboard_coding display-local.
Karoly Lorentey <lorentey@elte.hu>
parents:
54320
diff
changeset
|
300 #include "termhooks.h" |
17052 | 301 |
88365 | 302 Lisp_Object Vcoding_system_hash_table; |
303 | |
304 Lisp_Object Qcoding_system, Qcoding_aliases, Qeol_type; | |
88646
d3b1f30e2267
(Qmac): Remove (duplicated) definition.
Dave Love <fx@gnu.org>
parents:
88645
diff
changeset
|
305 Lisp_Object Qunix, Qdos; |
17052 | 306 Lisp_Object Qbuffer_file_coding_system; |
307 Lisp_Object Qpost_read_conversion, Qpre_write_conversion; | |
88365 | 308 Lisp_Object Qdefault_char; |
19612
783efd6c7c1e
(Qno_conversion, Qundecided): New variables.
Kenichi Handa <handa@m17n.org>
parents:
19546
diff
changeset
|
309 Lisp_Object Qno_conversion, Qundecided; |
88365 | 310 Lisp_Object Qcharset, Qiso_2022, Qutf_8, Qutf_16, Qshift_jis, Qbig5; |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
311 Lisp_Object Qbig, Qlittle; |
19750
95e4e1cba6ac
(Qcoding_system_history): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
19747
diff
changeset
|
312 Lisp_Object Qcoding_system_history; |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
313 Lisp_Object Qvalid_codes; |
100303
3e044fa54e4f
* coding.c (QCdefault_char): Rename from QCdefalut_char.
Juanma Barranquero <lekktu@gmail.com>
parents:
100262
diff
changeset
|
314 Lisp_Object QCcategory, QCmnemonic, QCdefault_char; |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
315 Lisp_Object QCdecode_translation_table, QCencode_translation_table; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
316 Lisp_Object QCpost_read_conversion, QCpre_write_conversion; |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
317 Lisp_Object QCascii_compatible_p; |
17052 | 318 |
64251
3de1b955c31a
* coding.c (Qprocess_argument):
Kim F. Storm <storm@cua.dk>
parents:
64084
diff
changeset
|
319 Lisp_Object Qcall_process, Qcall_process_region; |
17052 | 320 Lisp_Object Qstart_process, Qopen_network_stream; |
321 Lisp_Object Qtarget_idx; | |
322 | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
323 Lisp_Object Qinsufficient_source, Qinconsistent_eol, Qinvalid_source; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
324 Lisp_Object Qinterrupted, Qinsufficient_memory; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
325 |
52794
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
326 /* If a symbol has this property, evaluate the value to define the |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
327 symbol as a coding system. */ |
90272
f1df126ec7de
Sync to HEAD for handling autoload-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
90263
diff
changeset
|
328 static Lisp_Object Qcoding_system_define_form; |
f1df126ec7de
Sync to HEAD for handling autoload-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
90263
diff
changeset
|
329 |
89483 | 330 int coding_system_require_warning; |
52794
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
331 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
332 Lisp_Object Vselect_safe_coding_system_function; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
333 |
24200
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
334 /* Mnemonic string for each format of end-of-line. */ |
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
335 Lisp_Object eol_mnemonic_unix, eol_mnemonic_dos, eol_mnemonic_mac; |
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
336 /* Mnemonic string to indicate format of end-of-line is not yet |
17052 | 337 decided. */ |
24200
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
338 Lisp_Object eol_mnemonic_undecided; |
17052 | 339 |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
340 /* Format of end-of-line decided by system. This is Qunix on |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
341 Unix and Mac, Qdos on DOS/Windows. |
70520
b6740a317343
(setup_coding_system): For invalid coding-system, set
Kenichi Handa <handa@m17n.org>
parents:
69995
diff
changeset
|
342 This has an effect only for external encoding (i.e. for output to |
b6740a317343
(setup_coding_system): For invalid coding-system, set
Kenichi Handa <handa@m17n.org>
parents:
69995
diff
changeset
|
343 file and process), not for in-buffer or Lisp string encoding. */ |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
344 static Lisp_Object system_eol_type; |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
345 |
17052 | 346 #ifdef emacs |
347 | |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
348 Lisp_Object Vcoding_system_list, Vcoding_system_alist; |
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
349 |
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
350 Lisp_Object Qcoding_system_p, Qcoding_system_error; |
17052 | 351 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
352 /* Coding system emacs-mule and raw-text are for converting only |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
353 end-of-line format. */ |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
354 Lisp_Object Qemacs_mule, Qraw_text; |
89483 | 355 Lisp_Object Qutf_8_emacs; |
51406 | 356 |
17052 | 357 /* Coding-systems are handed between Emacs Lisp programs and C internal |
358 routines by the following three variables. */ | |
359 /* Coding-system for reading files and receiving data from process. */ | |
360 Lisp_Object Vcoding_system_for_read; | |
361 /* Coding-system for writing files and sending data to process. */ | |
362 Lisp_Object Vcoding_system_for_write; | |
363 /* Coding-system actually used in the latest I/O. */ | |
364 Lisp_Object Vlast_coding_system_used; | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
365 /* Set to non-nil when an error is detected while code conversion. */ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
366 Lisp_Object Vlast_code_conversion_error; |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
367 /* A vector of length 256 which contains information about special |
22529 | 368 Latin codes (especially for dealing with Microsoft codes). */ |
19365
d9374f5ebd3a
(CODING_FLAG_ISO_LATIN_EXTRA): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19285
diff
changeset
|
369 Lisp_Object Vlatin_extra_code_table; |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
370 |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
371 /* Flag to inhibit code conversion of end-of-line format. */ |
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
372 int inhibit_eol_conversion; |
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
373 |
30204
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
374 /* Flag to inhibit ISO2022 escape sequence detection. */ |
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
375 int inhibit_iso_escape_detection; |
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
376 |
101040 | 377 /* Flag to inhibit detection of binary files through null bytes. */ |
378 int inhibit_null_byte_detection; | |
379 | |
21574
30394e3ae7f8
(syms_of_coding): Declare and define inherit-process-coding-system.
Eli Zaretskii <eliz@gnu.org>
parents:
21520
diff
changeset
|
380 /* Flag to make buffer-file-coding-system inherit from process-coding. */ |
30394e3ae7f8
(syms_of_coding): Declare and define inherit-process-coding-system.
Eli Zaretskii <eliz@gnu.org>
parents:
21520
diff
changeset
|
381 int inherit_process_coding_system; |
30394e3ae7f8
(syms_of_coding): Declare and define inherit-process-coding-system.
Eli Zaretskii <eliz@gnu.org>
parents:
21520
diff
changeset
|
382 |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
383 /* Coding system to be used to encode text for terminal display when |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
384 terminal coding system is nil. */ |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
385 struct coding_system safe_terminal_coding; |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
386 |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
387 Lisp_Object Vfile_coding_system_alist; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
388 Lisp_Object Vprocess_coding_system_alist; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
389 Lisp_Object Vnetwork_coding_system_alist; |
17052 | 390 |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
391 Lisp_Object Vlocale_coding_system; |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
392 |
17052 | 393 #endif /* emacs */ |
394 | |
22186
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
395 /* Flag to tell if we look up translation table on character code |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
396 conversion. */ |
22119
592bb8b9bcfd
Change terms unify/unification to
Kenichi Handa <handa@m17n.org>
parents:
22020
diff
changeset
|
397 Lisp_Object Venable_character_translation; |
22186
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
398 /* Standard translation table to look up on decoding (reading). */ |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
399 Lisp_Object Vstandard_translation_table_for_decode; |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
400 /* Standard translation table to look up on encoding (writing). */ |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
401 Lisp_Object Vstandard_translation_table_for_encode; |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
402 |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
403 Lisp_Object Qtranslation_table; |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
404 Lisp_Object Qtranslation_table_id; |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
405 Lisp_Object Qtranslation_table_for_decode; |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
406 Lisp_Object Qtranslation_table_for_encode; |
17052 | 407 |
408 /* Alist of charsets vs revision number. */ | |
88365 | 409 static Lisp_Object Vcharset_revision_table; |
17052 | 410 |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
411 /* Default coding systems used for process I/O. */ |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
412 Lisp_Object Vdefault_process_coding_system; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
413 |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
414 /* Char table for translating Quail and self-inserting input. */ |
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
415 Lisp_Object Vtranslation_table_for_input; |
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
416 |
88365 | 417 /* Two special coding systems. */ |
418 Lisp_Object Vsjis_coding_system; | |
419 Lisp_Object Vbig5_coding_system; | |
420 | |
421 /* ISO2022 section */ | |
422 | |
423 #define CODING_ISO_INITIAL(coding, reg) \ | |
424 (XINT (AREF (AREF (CODING_ID_ATTRS ((coding)->id), \ | |
425 coding_attr_iso_initial), \ | |
426 reg))) | |
427 | |
428 | |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
429 #define CODING_ISO_REQUEST(coding, charset_id) \ |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
430 (((charset_id) <= (coding)->max_charset_id \ |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
431 ? ((coding)->safe_charsets[charset_id] != 255 \ |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
432 ? (coding)->safe_charsets[charset_id] \ |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
433 : -1) \ |
88365 | 434 : -1)) |
435 | |
436 | |
437 #define CODING_ISO_FLAGS(coding) \ | |
438 ((coding)->spec.iso_2022.flags) | |
439 #define CODING_ISO_DESIGNATION(coding, reg) \ | |
440 ((coding)->spec.iso_2022.current_designation[reg]) | |
441 #define CODING_ISO_INVOCATION(coding, plane) \ | |
442 ((coding)->spec.iso_2022.current_invocation[plane]) | |
443 #define CODING_ISO_SINGLE_SHIFTING(coding) \ | |
444 ((coding)->spec.iso_2022.single_shifting) | |
445 #define CODING_ISO_BOL(coding) \ | |
446 ((coding)->spec.iso_2022.bol) | |
447 #define CODING_ISO_INVOKED_CHARSET(coding, plane) \ | |
448 CODING_ISO_DESIGNATION ((coding), CODING_ISO_INVOCATION ((coding), (plane))) | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
449 #define CODING_ISO_CMP_STATUS(coding) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
450 (&(coding)->spec.iso_2022.cmp_status) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
451 #define CODING_ISO_EXTSEGMENT_LEN(coding) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
452 ((coding)->spec.iso_2022.ctext_extended_segment_len) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
453 #define CODING_ISO_EMBEDDED_UTF_8(coding) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
454 ((coding)->spec.iso_2022.embedded_utf_8) |
88365 | 455 |
456 /* Control characters of ISO2022. */ | |
457 /* code */ /* function */ | |
458 #define ISO_CODE_LF 0x0A /* line-feed */ | |
459 #define ISO_CODE_CR 0x0D /* carriage-return */ | |
460 #define ISO_CODE_SO 0x0E /* shift-out */ | |
461 #define ISO_CODE_SI 0x0F /* shift-in */ | |
462 #define ISO_CODE_SS2_7 0x19 /* single-shift-2 for 7-bit code */ | |
463 #define ISO_CODE_ESC 0x1B /* escape */ | |
464 #define ISO_CODE_SS2 0x8E /* single-shift-2 */ | |
465 #define ISO_CODE_SS3 0x8F /* single-shift-3 */ | |
466 #define ISO_CODE_CSI 0x9B /* control-sequence-introducer */ | |
467 | |
468 /* All code (1-byte) of ISO2022 is classified into one of the | |
469 followings. */ | |
470 enum iso_code_class_type | |
471 { | |
472 ISO_control_0, /* Control codes in the range | |
473 0x00..0x1F and 0x7F, except for the | |
474 following 5 codes. */ | |
475 ISO_shift_out, /* ISO_CODE_SO (0x0E) */ | |
476 ISO_shift_in, /* ISO_CODE_SI (0x0F) */ | |
477 ISO_single_shift_2_7, /* ISO_CODE_SS2_7 (0x19) */ | |
478 ISO_escape, /* ISO_CODE_SO (0x1B) */ | |
479 ISO_control_1, /* Control codes in the range | |
480 0x80..0x9F, except for the | |
481 following 3 codes. */ | |
482 ISO_single_shift_2, /* ISO_CODE_SS2 (0x8E) */ | |
483 ISO_single_shift_3, /* ISO_CODE_SS3 (0x8F) */ | |
484 ISO_control_sequence_introducer, /* ISO_CODE_CSI (0x9B) */ | |
485 ISO_0x20_or_0x7F, /* Codes of the values 0x20 or 0x7F. */ | |
486 ISO_graphic_plane_0, /* Graphic codes in the range 0x21..0x7E. */ | |
487 ISO_0xA0_or_0xFF, /* Codes of the values 0xA0 or 0xFF. */ | |
488 ISO_graphic_plane_1 /* Graphic codes in the range 0xA1..0xFE. */ | |
489 }; | |
490 | |
491 /** The macros CODING_ISO_FLAG_XXX defines a flag bit of the | |
492 `iso-flags' attribute of an iso2022 coding system. */ | |
493 | |
494 /* If set, produce long-form designation sequence (e.g. ESC $ ( A) | |
495 instead of the correct short-form sequence (e.g. ESC $ A). */ | |
496 #define CODING_ISO_FLAG_LONG_FORM 0x0001 | |
497 | |
498 /* If set, reset graphic planes and registers at end-of-line to the | |
499 initial state. */ | |
500 #define CODING_ISO_FLAG_RESET_AT_EOL 0x0002 | |
501 | |
502 /* If set, reset graphic planes and registers before any control | |
503 characters to the initial state. */ | |
504 #define CODING_ISO_FLAG_RESET_AT_CNTL 0x0004 | |
505 | |
506 /* If set, encode by 7-bit environment. */ | |
507 #define CODING_ISO_FLAG_SEVEN_BITS 0x0008 | |
508 | |
509 /* If set, use locking-shift function. */ | |
510 #define CODING_ISO_FLAG_LOCKING_SHIFT 0x0010 | |
511 | |
512 /* If set, use single-shift function. Overwrite | |
513 CODING_ISO_FLAG_LOCKING_SHIFT. */ | |
514 #define CODING_ISO_FLAG_SINGLE_SHIFT 0x0020 | |
515 | |
516 /* If set, use designation escape sequence. */ | |
517 #define CODING_ISO_FLAG_DESIGNATION 0x0040 | |
518 | |
519 /* If set, produce revision number sequence. */ | |
520 #define CODING_ISO_FLAG_REVISION 0x0080 | |
521 | |
522 /* If set, produce ISO6429's direction specifying sequence. */ | |
523 #define CODING_ISO_FLAG_DIRECTION 0x0100 | |
524 | |
525 /* If set, assume designation states are reset at beginning of line on | |
526 output. */ | |
527 #define CODING_ISO_FLAG_INIT_AT_BOL 0x0200 | |
528 | |
529 /* If set, designation sequence should be placed at beginning of line | |
530 on output. */ | |
531 #define CODING_ISO_FLAG_DESIGNATE_AT_BOL 0x0400 | |
532 | |
110983 | 533 /* If set, do not encode unsafe characters on output. */ |
88365 | 534 #define CODING_ISO_FLAG_SAFE 0x0800 |
535 | |
536 /* If set, extra latin codes (128..159) are accepted as a valid code | |
537 on input. */ | |
538 #define CODING_ISO_FLAG_LATIN_EXTRA 0x1000 | |
539 | |
540 #define CODING_ISO_FLAG_COMPOSITION 0x2000 | |
541 | |
542 #define CODING_ISO_FLAG_EUC_TW_SHIFT 0x4000 | |
543 | |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
544 #define CODING_ISO_FLAG_USE_ROMAN 0x8000 |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
545 |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
546 #define CODING_ISO_FLAG_USE_OLDJIS 0x10000 |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
547 |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
548 #define CODING_ISO_FLAG_FULL_SUPPORT 0x100000 |
88365 | 549 |
550 /* A character to be produced on output if encoding of the original | |
551 character is prohibited by CODING_ISO_FLAG_SAFE. */ | |
552 #define CODING_INHIBIT_CHARACTER_SUBSTITUTION '?' | |
553 | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
554 /* UTF-8 section */ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
555 #define CODING_UTF_8_BOM(coding) \ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
556 ((coding)->spec.utf_8_bom) |
88365 | 557 |
558 /* UTF-16 section */ | |
559 #define CODING_UTF_16_BOM(coding) \ | |
560 ((coding)->spec.utf_16.bom) | |
561 | |
562 #define CODING_UTF_16_ENDIAN(coding) \ | |
563 ((coding)->spec.utf_16.endian) | |
564 | |
565 #define CODING_UTF_16_SURROGATE(coding) \ | |
566 ((coding)->spec.utf_16.surrogate) | |
567 | |
568 | |
569 /* CCL section */ | |
570 #define CODING_CCL_DECODER(coding) \ | |
571 AREF (CODING_ID_ATTRS ((coding)->id), coding_attr_ccl_decoder) | |
572 #define CODING_CCL_ENCODER(coding) \ | |
573 AREF (CODING_ID_ATTRS ((coding)->id), coding_attr_ccl_encoder) | |
574 #define CODING_CCL_VALIDS(coding) \ | |
89483 | 575 (SDATA (AREF (CODING_ID_ATTRS ((coding)->id), coding_attr_ccl_valids))) |
88365 | 576 |
88771 | 577 /* Index for each coding category in `coding_categories' */ |
88365 | 578 |
579 enum coding_category | |
580 { | |
581 coding_category_iso_7, | |
582 coding_category_iso_7_tight, | |
583 coding_category_iso_8_1, | |
584 coding_category_iso_8_2, | |
585 coding_category_iso_7_else, | |
586 coding_category_iso_8_else, | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
587 coding_category_utf_8_auto, |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
588 coding_category_utf_8_nosig, |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
589 coding_category_utf_8_sig, |
88365 | 590 coding_category_utf_16_auto, |
591 coding_category_utf_16_be, | |
592 coding_category_utf_16_le, | |
593 coding_category_utf_16_be_nosig, | |
594 coding_category_utf_16_le_nosig, | |
595 coding_category_charset, | |
596 coding_category_sjis, | |
597 coding_category_big5, | |
598 coding_category_ccl, | |
599 coding_category_emacs_mule, | |
600 /* All above are targets of code detection. */ | |
601 coding_category_raw_text, | |
602 coding_category_undecided, | |
603 coding_category_max | |
604 }; | |
605 | |
606 /* Definitions of flag bits used in detect_coding_XXXX. */ | |
607 #define CATEGORY_MASK_ISO_7 (1 << coding_category_iso_7) | |
608 #define CATEGORY_MASK_ISO_7_TIGHT (1 << coding_category_iso_7_tight) | |
609 #define CATEGORY_MASK_ISO_8_1 (1 << coding_category_iso_8_1) | |
610 #define CATEGORY_MASK_ISO_8_2 (1 << coding_category_iso_8_2) | |
611 #define CATEGORY_MASK_ISO_7_ELSE (1 << coding_category_iso_7_else) | |
612 #define CATEGORY_MASK_ISO_8_ELSE (1 << coding_category_iso_8_else) | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
613 #define CATEGORY_MASK_UTF_8_AUTO (1 << coding_category_utf_8_auto) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
614 #define CATEGORY_MASK_UTF_8_NOSIG (1 << coding_category_utf_8_nosig) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
615 #define CATEGORY_MASK_UTF_8_SIG (1 << coding_category_utf_8_sig) |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
616 #define CATEGORY_MASK_UTF_16_AUTO (1 << coding_category_utf_16_auto) |
88365 | 617 #define CATEGORY_MASK_UTF_16_BE (1 << coding_category_utf_16_be) |
618 #define CATEGORY_MASK_UTF_16_LE (1 << coding_category_utf_16_le) | |
619 #define CATEGORY_MASK_UTF_16_BE_NOSIG (1 << coding_category_utf_16_be_nosig) | |
620 #define CATEGORY_MASK_UTF_16_LE_NOSIG (1 << coding_category_utf_16_le_nosig) | |
621 #define CATEGORY_MASK_CHARSET (1 << coding_category_charset) | |
622 #define CATEGORY_MASK_SJIS (1 << coding_category_sjis) | |
623 #define CATEGORY_MASK_BIG5 (1 << coding_category_big5) | |
624 #define CATEGORY_MASK_CCL (1 << coding_category_ccl) | |
625 #define CATEGORY_MASK_EMACS_MULE (1 << coding_category_emacs_mule) | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
626 #define CATEGORY_MASK_RAW_TEXT (1 << coding_category_raw_text) |
88365 | 627 |
628 /* This value is returned if detect_coding_mask () find nothing other | |
629 than ASCII characters. */ | |
630 #define CATEGORY_MASK_ANY \ | |
631 (CATEGORY_MASK_ISO_7 \ | |
632 | CATEGORY_MASK_ISO_7_TIGHT \ | |
633 | CATEGORY_MASK_ISO_8_1 \ | |
634 | CATEGORY_MASK_ISO_8_2 \ | |
635 | CATEGORY_MASK_ISO_7_ELSE \ | |
636 | CATEGORY_MASK_ISO_8_ELSE \ | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
637 | CATEGORY_MASK_UTF_8_AUTO \ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
638 | CATEGORY_MASK_UTF_8_NOSIG \ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
639 | CATEGORY_MASK_UTF_8_SIG \ |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
640 | CATEGORY_MASK_UTF_16_AUTO \ |
88365 | 641 | CATEGORY_MASK_UTF_16_BE \ |
642 | CATEGORY_MASK_UTF_16_LE \ | |
643 | CATEGORY_MASK_UTF_16_BE_NOSIG \ | |
644 | CATEGORY_MASK_UTF_16_LE_NOSIG \ | |
645 | CATEGORY_MASK_CHARSET \ | |
646 | CATEGORY_MASK_SJIS \ | |
647 | CATEGORY_MASK_BIG5 \ | |
648 | CATEGORY_MASK_CCL \ | |
649 | CATEGORY_MASK_EMACS_MULE) | |
650 | |
651 | |
652 #define CATEGORY_MASK_ISO_7BIT \ | |
653 (CATEGORY_MASK_ISO_7 | CATEGORY_MASK_ISO_7_TIGHT) | |
654 | |
655 #define CATEGORY_MASK_ISO_8BIT \ | |
656 (CATEGORY_MASK_ISO_8_1 | CATEGORY_MASK_ISO_8_2) | |
657 | |
658 #define CATEGORY_MASK_ISO_ELSE \ | |
659 (CATEGORY_MASK_ISO_7_ELSE | CATEGORY_MASK_ISO_8_ELSE) | |
660 | |
661 #define CATEGORY_MASK_ISO_ESCAPE \ | |
662 (CATEGORY_MASK_ISO_7 \ | |
663 | CATEGORY_MASK_ISO_7_TIGHT \ | |
664 | CATEGORY_MASK_ISO_7_ELSE \ | |
665 | CATEGORY_MASK_ISO_8_ELSE) | |
666 | |
667 #define CATEGORY_MASK_ISO \ | |
668 ( CATEGORY_MASK_ISO_7BIT \ | |
669 | CATEGORY_MASK_ISO_8BIT \ | |
670 | CATEGORY_MASK_ISO_ELSE) | |
671 | |
672 #define CATEGORY_MASK_UTF_16 \ | |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
673 (CATEGORY_MASK_UTF_16_AUTO \ |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
674 | CATEGORY_MASK_UTF_16_BE \ |
88365 | 675 | CATEGORY_MASK_UTF_16_LE \ |
676 | CATEGORY_MASK_UTF_16_BE_NOSIG \ | |
677 | CATEGORY_MASK_UTF_16_LE_NOSIG) | |
678 | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
679 #define CATEGORY_MASK_UTF_8 \ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
680 (CATEGORY_MASK_UTF_8_AUTO \ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
681 | CATEGORY_MASK_UTF_8_NOSIG \ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
682 | CATEGORY_MASK_UTF_8_SIG) |
88365 | 683 |
684 /* List of symbols `coding-category-xxx' ordered by priority. This | |
685 variable is exposed to Emacs Lisp. */ | |
686 static Lisp_Object Vcoding_category_list; | |
687 | |
688 /* Table of coding categories (Lisp symbols). This variable is for | |
110983 | 689 internal use only. */ |
88365 | 690 static Lisp_Object Vcoding_category_table; |
691 | |
692 /* Table of coding-categories ordered by priority. */ | |
693 static enum coding_category coding_priorities[coding_category_max]; | |
694 | |
695 /* Nth element is a coding context for the coding system bound to the | |
696 Nth coding category. */ | |
697 static struct coding_system coding_categories[coding_category_max]; | |
698 | |
699 /*** Commonly used macros and functions ***/ | |
700 | |
701 #ifndef min | |
702 #define min(a, b) ((a) < (b) ? (a) : (b)) | |
703 #endif | |
704 #ifndef max | |
705 #define max(a, b) ((a) > (b) ? (a) : (b)) | |
706 #endif | |
707 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
708 #define CODING_GET_INFO(coding, attrs, charset_list) \ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
709 do { \ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
710 (attrs) = CODING_ID_ATTRS ((coding)->id); \ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
711 (charset_list) = CODING_ATTR_CHARSET_LIST (attrs); \ |
88365 | 712 } while (0) |
713 | |
714 | |
715 /* Safely get one byte from the source text pointed by SRC which ends | |
716 at SRC_END, and set C to that byte. If there are not enough bytes | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
717 in the source, it jumps to `no_more_source'. If multibytep is |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
718 nonzero, and a multibyte character is found at SRC, set C to the |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
719 negative value of the character code. The caller should declare |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
720 and set these variables appropriately in advance: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
721 src, src_end, multibytep */ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
722 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
723 #define ONE_MORE_BYTE(c) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
724 do { \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
725 if (src == src_end) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
726 { \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
727 if (src_base < src) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
728 record_conversion_result \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
729 (coding, CODING_RESULT_INSUFFICIENT_SRC); \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
730 goto no_more_source; \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
731 } \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
732 c = *src++; \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
733 if (multibytep && (c & 0x80)) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
734 { \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
735 if ((c & 0xFE) == 0xC0) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
736 c = ((c & 1) << 6) | *src++; \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
737 else \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
738 { \ |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
739 src--; \ |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
740 c = - string_char (src, &src, NULL); \ |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
741 record_conversion_result \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
742 (coding, CODING_RESULT_INVALID_SRC); \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
743 } \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
744 } \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
745 consumed_chars++; \ |
88365 | 746 } while (0) |
747 | |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
748 /* Safely get two bytes from the source text pointed by SRC which ends |
101174 | 749 at SRC_END, and set C1 and C2 to those bytes while skipping the |
750 heading multibyte characters. If there are not enough bytes in the | |
751 source, it jumps to `no_more_source'. If multibytep is nonzero and | |
752 a multibyte character is found for C2, set C2 to the negative value | |
753 of the character code. The caller should declare and set these | |
754 variables appropriately in advance: | |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
755 src, src_end, multibytep |
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
756 It is intended that this macro is used in detect_coding_utf_16. */ |
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
757 |
101174 | 758 #define TWO_MORE_BYTES(c1, c2) \ |
759 do { \ | |
760 do { \ | |
761 if (src == src_end) \ | |
762 goto no_more_source; \ | |
763 c1 = *src++; \ | |
764 if (multibytep && (c1 & 0x80)) \ | |
765 { \ | |
766 if ((c1 & 0xFE) == 0xC0) \ | |
767 c1 = ((c1 & 1) << 6) | *src++; \ | |
768 else \ | |
769 { \ | |
770 src += BYTES_BY_CHAR_HEAD (c1) - 1; \ | |
771 c1 = -1; \ | |
772 } \ | |
773 } \ | |
774 } while (c1 < 0); \ | |
775 if (src == src_end) \ | |
776 goto no_more_source; \ | |
777 c2 = *src++; \ | |
778 if (multibytep && (c2 & 0x80)) \ | |
779 { \ | |
780 if ((c2 & 0xFE) == 0xC0) \ | |
781 c2 = ((c2 & 1) << 6) | *src++; \ | |
782 else \ | |
783 c2 = -1; \ | |
784 } \ | |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
785 } while (0) |
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
786 |
88365 | 787 |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
788 #define ONE_MORE_BYTE_NO_CHECK(c) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
789 do { \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
790 c = *src++; \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
791 if (multibytep && (c & 0x80)) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
792 { \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
793 if ((c & 0xFE) == 0xC0) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
794 c = ((c & 1) << 6) | *src++; \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
795 else \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
796 { \ |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
797 src--; \ |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
798 c = - string_char (src, &src, NULL); \ |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
799 record_conversion_result \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
800 (coding, CODING_RESULT_INVALID_SRC); \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
801 } \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
802 } \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
803 consumed_chars++; \ |
88365 | 804 } while (0) |
805 | |
806 | |
807 /* Store a byte C in the place pointed by DST and increment DST to the | |
808 next free point, and increment PRODUCED_CHARS. The caller should | |
809 assure that C is 0..127, and declare and set the variable `dst' | |
810 appropriately in advance. | |
811 */ | |
812 | |
813 | |
814 #define EMIT_ONE_ASCII_BYTE(c) \ | |
815 do { \ | |
816 produced_chars++; \ | |
817 *dst++ = (c); \ | |
818 } while (0) | |
819 | |
820 | |
110983 | 821 /* Like EMIT_ONE_ASCII_BYTE but store two bytes; C1 and C2. */ |
88365 | 822 |
823 #define EMIT_TWO_ASCII_BYTES(c1, c2) \ | |
824 do { \ | |
825 produced_chars += 2; \ | |
826 *dst++ = (c1), *dst++ = (c2); \ | |
827 } while (0) | |
828 | |
829 | |
830 /* Store a byte C in the place pointed by DST and increment DST to the | |
831 next free point, and increment PRODUCED_CHARS. If MULTIBYTEP is | |
832 nonzero, store in an appropriate multibyte from. The caller should | |
833 declare and set the variables `dst' and `multibytep' appropriately | |
834 in advance. */ | |
835 | |
836 #define EMIT_ONE_BYTE(c) \ | |
837 do { \ | |
838 produced_chars++; \ | |
839 if (multibytep) \ | |
840 { \ | |
841 int ch = (c); \ | |
842 if (ch >= 0x80) \ | |
843 ch = BYTE8_TO_CHAR (ch); \ | |
844 CHAR_STRING_ADVANCE (ch, dst); \ | |
845 } \ | |
846 else \ | |
847 *dst++ = (c); \ | |
848 } while (0) | |
849 | |
850 | |
851 /* Like EMIT_ONE_BYTE, but emit two bytes; C1 and C2. */ | |
852 | |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
853 #define EMIT_TWO_BYTES(c1, c2) \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
854 do { \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
855 produced_chars += 2; \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
856 if (multibytep) \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
857 { \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
858 int ch; \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
859 \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
860 ch = (c1); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
861 if (ch >= 0x80) \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
862 ch = BYTE8_TO_CHAR (ch); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
863 CHAR_STRING_ADVANCE (ch, dst); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
864 ch = (c2); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
865 if (ch >= 0x80) \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
866 ch = BYTE8_TO_CHAR (ch); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
867 CHAR_STRING_ADVANCE (ch, dst); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
868 } \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
869 else \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
870 { \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
871 *dst++ = (c1); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
872 *dst++ = (c2); \ |
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
873 } \ |
88365 | 874 } while (0) |
875 | |
876 | |
877 #define EMIT_THREE_BYTES(c1, c2, c3) \ | |
878 do { \ | |
879 EMIT_ONE_BYTE (c1); \ | |
880 EMIT_TWO_BYTES (c2, c3); \ | |
881 } while (0) | |
882 | |
883 | |
884 #define EMIT_FOUR_BYTES(c1, c2, c3, c4) \ | |
885 do { \ | |
886 EMIT_TWO_BYTES (c1, c2); \ | |
887 EMIT_TWO_BYTES (c3, c4); \ | |
888 } while (0) | |
889 | |
890 | |
89863
428fc37b2ae6
Add many prototypes for static functions.
Kenichi Handa <handa@m17n.org>
parents:
89861
diff
changeset
|
891 /* Prototypes for static functions. */ |
109100
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
892 static void record_conversion_result (struct coding_system *coding, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
893 enum coding_result_code result); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
894 static int detect_coding_utf_8 (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
895 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
896 static void decode_coding_utf_8 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
897 static int encode_coding_utf_8 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
898 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
899 static int detect_coding_utf_16 (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
900 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
901 static void decode_coding_utf_16 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
902 static int encode_coding_utf_16 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
903 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
904 static int detect_coding_iso_2022 (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
905 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
906 static void decode_coding_iso_2022 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
907 static int encode_coding_iso_2022 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
908 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
909 static int detect_coding_emacs_mule (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
910 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
911 static void decode_coding_emacs_mule (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
912 static int encode_coding_emacs_mule (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
913 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
914 static int detect_coding_sjis (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
915 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
916 static void decode_coding_sjis (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
917 static int encode_coding_sjis (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
918 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
919 static int detect_coding_big5 (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
920 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
921 static void decode_coding_big5 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
922 static int encode_coding_big5 (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
923 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
924 static int detect_coding_ccl (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
925 struct coding_detection_info *info); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
926 static void decode_coding_ccl (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
927 static int encode_coding_ccl (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
928 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
929 static void decode_coding_raw_text (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
930 static int encode_coding_raw_text (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
931 |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
932 static void coding_set_source (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
933 static void coding_set_destination (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
934 static void coding_alloc_by_realloc (struct coding_system *, EMACS_INT); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
935 static void coding_alloc_by_making_gap (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
936 EMACS_INT, EMACS_INT); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
937 static unsigned char *alloc_destination (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
938 EMACS_INT, unsigned char *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
939 static void setup_iso_safe_charsets (Lisp_Object); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
940 static unsigned char *encode_designation_at_bol (struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
941 int *, int *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
942 unsigned char *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
943 static int detect_eol (const unsigned char *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
944 EMACS_INT, enum coding_category); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
945 static Lisp_Object adjust_coding_eol_type (struct coding_system *, int); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
946 static void decode_eol (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
947 static Lisp_Object get_translation_table (Lisp_Object, int, int *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
948 static Lisp_Object get_translation (Lisp_Object, int *, int *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
949 static int produce_chars (struct coding_system *, Lisp_Object, int); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
950 static INLINE void produce_charset (struct coding_system *, int *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
951 EMACS_INT); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
952 static void produce_annotation (struct coding_system *, EMACS_INT); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
953 static int decode_coding (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
954 static INLINE int *handle_composition_annotation (EMACS_INT, EMACS_INT, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
955 struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
956 int *, EMACS_INT *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
957 static INLINE int *handle_charset_annotation (EMACS_INT, EMACS_INT, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
958 struct coding_system *, |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
959 int *, EMACS_INT *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
960 static void consume_chars (struct coding_system *, Lisp_Object, int); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
961 static int encode_coding (struct coding_system *); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
962 static Lisp_Object make_conversion_work_buffer (int); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
963 static Lisp_Object code_conversion_restore (Lisp_Object); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
964 static INLINE int char_encodable_p (int, Lisp_Object); |
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
965 static Lisp_Object make_subsidiaries (Lisp_Object); |
89863
428fc37b2ae6
Add many prototypes for static functions.
Kenichi Handa <handa@m17n.org>
parents:
89861
diff
changeset
|
966 |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
967 static void |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
968 record_conversion_result (struct coding_system *coding, |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
969 enum coding_result_code result) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
970 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
971 coding->result = result; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
972 switch (result) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
973 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
974 case CODING_RESULT_INSUFFICIENT_SRC: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
975 Vlast_code_conversion_error = Qinsufficient_source; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
976 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
977 case CODING_RESULT_INCONSISTENT_EOL: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
978 Vlast_code_conversion_error = Qinconsistent_eol; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
979 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
980 case CODING_RESULT_INVALID_SRC: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
981 Vlast_code_conversion_error = Qinvalid_source; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
982 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
983 case CODING_RESULT_INTERRUPT: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
984 Vlast_code_conversion_error = Qinterrupted; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
985 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
986 case CODING_RESULT_INSUFFICIENT_MEM: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
987 Vlast_code_conversion_error = Qinsufficient_memory; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
988 break; |
107174
e98bd64897e0
Fix handling of CODING_RESULT_INSUFFICIENT_DST.
Kenichi Handa <handa@m17n.org>
parents:
107171
diff
changeset
|
989 case CODING_RESULT_INSUFFICIENT_DST: |
e98bd64897e0
Fix handling of CODING_RESULT_INSUFFICIENT_DST.
Kenichi Handa <handa@m17n.org>
parents:
107171
diff
changeset
|
990 /* Don't record this error in Vlast_code_conversion_error |
e98bd64897e0
Fix handling of CODING_RESULT_INSUFFICIENT_DST.
Kenichi Handa <handa@m17n.org>
parents:
107171
diff
changeset
|
991 because it happens just temporarily and is resolved when the |
e98bd64897e0
Fix handling of CODING_RESULT_INSUFFICIENT_DST.
Kenichi Handa <handa@m17n.org>
parents:
107171
diff
changeset
|
992 whole conversion is finished. */ |
e98bd64897e0
Fix handling of CODING_RESULT_INSUFFICIENT_DST.
Kenichi Handa <handa@m17n.org>
parents:
107171
diff
changeset
|
993 break; |
103133
2f7395806731
(record_conversion_result): Don't modify
Andreas Schwab <schwab@linux-m68k.org>
parents:
103052
diff
changeset
|
994 case CODING_RESULT_SUCCESS: |
2f7395806731
(record_conversion_result): Don't modify
Andreas Schwab <schwab@linux-m68k.org>
parents:
103052
diff
changeset
|
995 break; |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
996 default: |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
997 Vlast_code_conversion_error = intern ("Unknown error"); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
998 } |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
999 } |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1000 |
107321
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
1001 /* This wrapper macro is used to preserve validity of pointers into |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
1002 buffer text across calls to decode_char, which could cause |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
1003 relocation of buffers if it loads a charset map, because loading a |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
1004 charset map allocates large structures. */ |
88365 | 1005 #define CODING_DECODE_CHAR(coding, src, src_base, src_end, charset, code, c) \ |
1006 do { \ | |
1007 charset_map_loaded = 0; \ | |
1008 c = DECODE_CHAR (charset, code); \ | |
1009 if (charset_map_loaded) \ | |
1010 { \ | |
89483 | 1011 const unsigned char *orig = coding->source; \ |
88365 | 1012 EMACS_INT offset; \ |
1013 \ | |
1014 coding_set_source (coding); \ | |
1015 offset = coding->source - orig; \ | |
1016 src += offset; \ | |
1017 src_base += offset; \ | |
1018 src_end += offset; \ | |
1019 } \ | |
1020 } while (0) | |
1021 | |
1022 | |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1023 /* If there are at least BYTES length of room at dst, allocate memory |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1024 for coding->destination and update dst and dst_end. We don't have |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1025 to take care of coding->source which will be relocated. It is |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1026 handled by calling coding_set_source in encode_coding. */ |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1027 |
88365 | 1028 #define ASSURE_DESTINATION(bytes) \ |
1029 do { \ | |
1030 if (dst + (bytes) >= dst_end) \ | |
1031 { \ | |
1032 int more_bytes = charbuf_end - charbuf + (bytes); \ | |
1033 \ | |
1034 dst = alloc_destination (coding, more_bytes, dst); \ | |
1035 dst_end = coding->destination + coding->dst_bytes; \ | |
1036 } \ | |
1037 } while (0) | |
1038 | |
1039 | |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1040 /* Store multibyte form of the character C in P, and advance P to the |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1041 end of the multibyte form. This is like CHAR_STRING_ADVANCE but it |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1042 never calls MAYBE_UNIFY_CHAR. */ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1043 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1044 #define CHAR_STRING_ADVANCE_NO_UNIFY(c, p) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1045 do { \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1046 if ((c) <= MAX_1_BYTE_CHAR) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1047 *(p)++ = (c); \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1048 else if ((c) <= MAX_2_BYTE_CHAR) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1049 *(p)++ = (0xC0 | ((c) >> 6)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1050 *(p)++ = (0x80 | ((c) & 0x3F)); \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1051 else if ((c) <= MAX_3_BYTE_CHAR) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1052 *(p)++ = (0xE0 | ((c) >> 12)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1053 *(p)++ = (0x80 | (((c) >> 6) & 0x3F)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1054 *(p)++ = (0x80 | ((c) & 0x3F)); \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1055 else if ((c) <= MAX_4_BYTE_CHAR) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1056 *(p)++ = (0xF0 | (c >> 18)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1057 *(p)++ = (0x80 | ((c >> 12) & 0x3F)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1058 *(p)++ = (0x80 | ((c >> 6) & 0x3F)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1059 *(p)++ = (0x80 | (c & 0x3F)); \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1060 else if ((c) <= MAX_5_BYTE_CHAR) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1061 *(p)++ = 0xF8, \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1062 *(p)++ = (0x80 | ((c >> 18) & 0x0F)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1063 *(p)++ = (0x80 | ((c >> 12) & 0x3F)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1064 *(p)++ = (0x80 | ((c >> 6) & 0x3F)), \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1065 *(p)++ = (0x80 | (c & 0x3F)); \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1066 else \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1067 (p) += BYTE8_STRING ((c) - 0x3FFF80, p); \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1068 } while (0) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1069 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1070 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1071 /* Return the character code of character whose multibyte form is at |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1072 P, and advance P to the end of the multibyte form. This is like |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1073 STRING_CHAR_ADVANCE, but it never calls MAYBE_UNIFY_CHAR. */ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1074 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1075 #define STRING_CHAR_ADVANCE_NO_UNIFY(p) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1076 (!((p)[0] & 0x80) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1077 ? *(p)++ \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1078 : ! ((p)[0] & 0x20) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1079 ? ((p) += 2, \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1080 ((((p)[-2] & 0x1F) << 6) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1081 | ((p)[-1] & 0x3F) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1082 | ((unsigned char) ((p)[-2]) < 0xC2 ? 0x3FFF80 : 0))) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1083 : ! ((p)[0] & 0x10) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1084 ? ((p) += 3, \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1085 ((((p)[-3] & 0x0F) << 12) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1086 | (((p)[-2] & 0x3F) << 6) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1087 | ((p)[-1] & 0x3F))) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1088 : ! ((p)[0] & 0x08) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1089 ? ((p) += 4, \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1090 ((((p)[-4] & 0xF) << 18) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1091 | (((p)[-3] & 0x3F) << 12) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1092 | (((p)[-2] & 0x3F) << 6) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1093 | ((p)[-1] & 0x3F))) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1094 : ((p) += 5, \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1095 ((((p)[-4] & 0x3F) << 18) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1096 | (((p)[-3] & 0x3F) << 12) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1097 | (((p)[-2] & 0x3F) << 6) \ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1098 | ((p)[-1] & 0x3F)))) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1099 |
88365 | 1100 |
1101 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1102 coding_set_source (struct coding_system *coding) |
88365 | 1103 { |
1104 if (BUFFERP (coding->src_object)) | |
1105 { | |
89418
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
1106 struct buffer *buf = XBUFFER (coding->src_object); |
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
1107 |
88365 | 1108 if (coding->src_pos < 0) |
89418
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
1109 coding->source = BUF_GAP_END_ADDR (buf) + coding->src_pos_byte; |
88365 | 1110 else |
89418
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
1111 coding->source = BUF_BYTE_ADDRESS (buf, coding->src_pos_byte); |
88365 | 1112 } |
1113 else if (STRINGP (coding->src_object)) | |
1114 { | |
89483 | 1115 coding->source = SDATA (coding->src_object) + coding->src_pos_byte; |
88365 | 1116 } |
1117 else | |
1118 /* Otherwise, the source is C string and is never relocated | |
1119 automatically. Thus we don't have to update anything. */ | |
1120 ; | |
1121 } | |
1122 | |
1123 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1124 coding_set_destination (struct coding_system *coding) |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
1125 { |
88365 | 1126 if (BUFFERP (coding->dst_object)) |
1127 { | |
1128 if (coding->src_pos < 0) | |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1129 { |
91807
507bcfb4342c
* coding.c (coding_set_destination): Use BEG_BYTE rather than hardcoding 1.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91622
diff
changeset
|
1130 coding->destination = BEG_ADDR + coding->dst_pos_byte - BEG_BYTE; |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1131 coding->dst_bytes = (GAP_END_ADDR |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1132 - (coding->src_bytes - coding->consumed) |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1133 - coding->destination); |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1134 } |
88365 | 1135 else |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1136 { |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1137 /* We are sure that coding->dst_pos_byte is before the gap |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1138 of the buffer. */ |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1139 coding->destination = (BUF_BEG_ADDR (XBUFFER (coding->dst_object)) |
91807
507bcfb4342c
* coding.c (coding_set_destination): Use BEG_BYTE rather than hardcoding 1.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91622
diff
changeset
|
1140 + coding->dst_pos_byte - BEG_BYTE); |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1141 coding->dst_bytes = (BUF_GAP_END_ADDR (XBUFFER (coding->dst_object)) |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1142 - coding->destination); |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1143 } |
88365 | 1144 } |
1145 else | |
1146 /* Otherwise, the destination is C string and is never relocated | |
1147 automatically. Thus we don't have to update anything. */ | |
1148 ; | |
1149 } | |
1150 | |
1151 | |
1152 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1153 coding_alloc_by_realloc (struct coding_system *coding, EMACS_INT bytes) |
88365 | 1154 { |
1155 coding->destination = (unsigned char *) xrealloc (coding->destination, | |
1156 coding->dst_bytes + bytes); | |
1157 coding->dst_bytes += bytes; | |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
1158 } |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
1159 |
88365 | 1160 static void |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1161 coding_alloc_by_making_gap (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1162 EMACS_INT gap_head_used, EMACS_INT bytes) |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1163 { |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1164 if (EQ (coding->src_object, coding->dst_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1165 { |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1166 /* The gap may contain the produced data at the head and not-yet |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1167 consumed data at the tail. To preserve those data, we at |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1168 first make the gap size to zero, then increase the gap |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1169 size. */ |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1170 EMACS_INT add = GAP_SIZE; |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1171 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1172 GPT += gap_head_used, GPT_BYTE += gap_head_used; |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1173 GAP_SIZE = 0; ZV += add; Z += add; ZV_BYTE += add; Z_BYTE += add; |
88365 | 1174 make_gap (bytes); |
1175 GAP_SIZE += add; ZV -= add; Z -= add; ZV_BYTE -= add; Z_BYTE -= add; | |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1176 GPT -= gap_head_used, GPT_BYTE -= gap_head_used; |
88365 | 1177 } |
90292
697c08d95af7
Cancel incorrect synching with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90291
diff
changeset
|
1178 else |
88365 | 1179 { |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
1180 Lisp_Object this_buffer; |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
1181 |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
1182 this_buffer = Fcurrent_buffer (); |
88365 | 1183 set_buffer_internal (XBUFFER (coding->dst_object)); |
1184 make_gap (bytes); | |
1185 set_buffer_internal (XBUFFER (this_buffer)); | |
1186 } | |
1187 } | |
89483 | 1188 |
88365 | 1189 |
1190 static unsigned char * | |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1191 alloc_destination (struct coding_system *coding, EMACS_INT nbytes, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1192 unsigned char *dst) |
88365 | 1193 { |
1194 EMACS_INT offset = dst - coding->destination; | |
1195 | |
1196 if (BUFFERP (coding->dst_object)) | |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1197 { |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1198 struct buffer *buf = XBUFFER (coding->dst_object); |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1199 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1200 coding_alloc_by_making_gap (coding, dst - BUF_GPT_ADDR (buf), nbytes); |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1201 } |
88365 | 1202 else |
1203 coding_alloc_by_realloc (coding, nbytes); | |
1204 coding_set_destination (coding); | |
1205 dst = coding->destination + offset; | |
1206 return dst; | |
1207 } | |
1208 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1209 /** Macros for annotations. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1210 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1211 /* An annotation data is stored in the array coding->charbuf in this |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1212 format: |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1213 [ -LENGTH ANNOTATION_MASK NCHARS ... ] |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1214 LENGTH is the number of elements in the annotation. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1215 ANNOTATION_MASK is one of CODING_ANNOTATE_XXX_MASK. |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1216 NCHARS is the number of characters in the text annotated. |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1217 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1218 The format of the following elements depend on ANNOTATION_MASK. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1219 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1220 In the case of CODING_ANNOTATE_COMPOSITION_MASK, these elements |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1221 follows: |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1222 ... NBYTES METHOD [ COMPOSITION-COMPONENTS ... ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1223 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1224 NBYTES is the number of bytes specified in the header part of |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1225 old-style emacs-mule encoding, or 0 for the other kind of |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1226 composition. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1227 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1228 METHOD is one of enum composition_method. |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1229 |
110983 | 1230 Optional COMPOSITION-COMPONENTS are characters and composition |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1231 rules. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1232 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1233 In the case of CODING_ANNOTATE_CHARSET_MASK, one element CHARSET-ID |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1234 follows. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1235 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1236 If ANNOTATION_MASK is 0, this annotation is just a space holder to |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1237 recover from an invalid annotation, and should be skipped by |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1238 produce_annotation. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1239 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1240 /* Maximum length of the header of annotation data. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1241 #define MAX_ANNOTATION_LENGTH 5 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1242 |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1243 #define ADD_ANNOTATION_DATA(buf, len, mask, nchars) \ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1244 do { \ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1245 *(buf)++ = -(len); \ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1246 *(buf)++ = (mask); \ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1247 *(buf)++ = (nchars); \ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1248 coding->annotated = 1; \ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1249 } while (0); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1250 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1251 #define ADD_COMPOSITION_DATA(buf, nchars, nbytes, method) \ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1252 do { \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1253 ADD_ANNOTATION_DATA (buf, 5, CODING_ANNOTATE_COMPOSITION_MASK, nchars); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1254 *buf++ = nbytes; \ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1255 *buf++ = method; \ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1256 } while (0) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1257 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1258 |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1259 #define ADD_CHARSET_DATA(buf, nchars, id) \ |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1260 do { \ |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1261 ADD_ANNOTATION_DATA (buf, 4, CODING_ANNOTATE_CHARSET_MASK, nchars); \ |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1262 *buf++ = id; \ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1263 } while (0) |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
1264 |
17052 | 1265 |
88365 | 1266 /*** 2. Emacs' internal format (emacs-utf-8) ***/ |
1267 | |
1268 | |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
1269 |
17052 | 1270 |
88365 | 1271 /*** 3. UTF-8 ***/ |
1272 | |
1273 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1274 Check if a text is encoded in UTF-8. If it is, return 1, else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1275 return 0. */ |
88365 | 1276 |
1277 #define UTF_8_1_OCTET_P(c) ((c) < 0x80) | |
1278 #define UTF_8_EXTRA_OCTET_P(c) (((c) & 0xC0) == 0x80) | |
1279 #define UTF_8_2_OCTET_LEADING_P(c) (((c) & 0xE0) == 0xC0) | |
1280 #define UTF_8_3_OCTET_LEADING_P(c) (((c) & 0xF0) == 0xE0) | |
1281 #define UTF_8_4_OCTET_LEADING_P(c) (((c) & 0xF8) == 0xF0) | |
1282 #define UTF_8_5_OCTET_LEADING_P(c) (((c) & 0xFC) == 0xF8) | |
1283 | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1284 #define UTF_BOM 0xFEFF |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1285 #define UTF_8_BOM_1 0xEF |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1286 #define UTF_8_BOM_2 0xBB |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1287 #define UTF_8_BOM_3 0xBF |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1288 |
88365 | 1289 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1290 detect_coding_utf_8 (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1291 struct coding_detection_info *detect_info) |
88365 | 1292 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1293 const unsigned char *src = coding->source, *src_base; |
89483 | 1294 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 1295 int multibytep = coding->src_multibyte; |
1296 int consumed_chars = 0; | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1297 int bom_found = 0; |
88365 | 1298 int found = 0; |
1299 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1300 detect_info->checked |= CATEGORY_MASK_UTF_8; |
88365 | 1301 /* A coding system of this category is always ASCII compatible. */ |
1302 src += coding->head_ascii; | |
1303 | |
1304 while (1) | |
1305 { | |
1306 int c, c1, c2, c3, c4; | |
1307 | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1308 src_base = src; |
88365 | 1309 ONE_MORE_BYTE (c); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1310 if (c < 0 || UTF_8_1_OCTET_P (c)) |
88365 | 1311 continue; |
1312 ONE_MORE_BYTE (c1); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1313 if (c1 < 0 || ! UTF_8_EXTRA_OCTET_P (c1)) |
88365 | 1314 break; |
1315 if (UTF_8_2_OCTET_LEADING_P (c)) | |
1316 { | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1317 found = 1; |
88365 | 1318 continue; |
1319 } | |
1320 ONE_MORE_BYTE (c2); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1321 if (c2 < 0 || ! UTF_8_EXTRA_OCTET_P (c2)) |
88365 | 1322 break; |
1323 if (UTF_8_3_OCTET_LEADING_P (c)) | |
1324 { | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1325 found = 1; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1326 if (src_base == coding->source |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1327 && c == UTF_8_BOM_1 && c1 == UTF_8_BOM_2 && c2 == UTF_8_BOM_3) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1328 bom_found = 1; |
88365 | 1329 continue; |
1330 } | |
1331 ONE_MORE_BYTE (c3); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1332 if (c3 < 0 || ! UTF_8_EXTRA_OCTET_P (c3)) |
88365 | 1333 break; |
1334 if (UTF_8_4_OCTET_LEADING_P (c)) | |
1335 { | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1336 found = 1; |
88365 | 1337 continue; |
1338 } | |
1339 ONE_MORE_BYTE (c4); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1340 if (c4 < 0 || ! UTF_8_EXTRA_OCTET_P (c4)) |
88365 | 1341 break; |
1342 if (UTF_8_5_OCTET_LEADING_P (c)) | |
1343 { | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1344 found = 1; |
88365 | 1345 continue; |
1346 } | |
1347 break; | |
1348 } | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1349 detect_info->rejected |= CATEGORY_MASK_UTF_8; |
88365 | 1350 return 0; |
1351 | |
1352 no_more_source: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1353 if (src_base < src && coding->mode & CODING_MODE_LAST_BLOCK) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
1354 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1355 detect_info->rejected |= CATEGORY_MASK_UTF_8; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
1356 return 0; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
1357 } |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1358 if (bom_found) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1359 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1360 /* The first character 0xFFFE doesn't necessarily mean a BOM. */ |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1361 detect_info->found |= CATEGORY_MASK_UTF_8_SIG | CATEGORY_MASK_UTF_8_NOSIG; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1362 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1363 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1364 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1365 detect_info->rejected |= CATEGORY_MASK_UTF_8_SIG; |
96571
a3f2a5a4b492
(detect_coding_utf_8): Set detect_info->found only when
Kenichi Handa <handa@m17n.org>
parents:
95585
diff
changeset
|
1366 if (found) |
a3f2a5a4b492
(detect_coding_utf_8): Set detect_info->found only when
Kenichi Handa <handa@m17n.org>
parents:
95585
diff
changeset
|
1367 detect_info->found |= CATEGORY_MASK_UTF_8_NOSIG; |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1368 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1369 return 1; |
88365 | 1370 } |
1371 | |
1372 | |
1373 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1374 decode_coding_utf_8 (struct coding_system *coding) |
88365 | 1375 { |
89483 | 1376 const unsigned char *src = coding->source + coding->consumed; |
1377 const unsigned char *src_end = coding->source + coding->src_bytes; | |
1378 const unsigned char *src_base; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1379 int *charbuf = coding->charbuf + coding->charbuf_used; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1380 int *charbuf_end = coding->charbuf + coding->charbuf_size; |
100133
bca35d7cb3ac
(decode_coding_utf_8): Likewise.
Kenichi Handa <handa@m17n.org>
parents:
100131
diff
changeset
|
1381 int consumed_chars = 0, consumed_chars_base = 0; |
88365 | 1382 int multibytep = coding->src_multibyte; |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1383 enum utf_bom_type bom = CODING_UTF_8_BOM (coding); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1384 Lisp_Object attr, charset_list; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
1385 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
1386 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1387 int byte_after_cr = -1; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1388 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1389 CODING_GET_INFO (coding, attr, charset_list); |
88365 | 1390 |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1391 if (bom != utf_without_bom) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1392 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1393 int c1, c2, c3; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1394 |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1395 src_base = src; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1396 ONE_MORE_BYTE (c1); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1397 if (! UTF_8_3_OCTET_LEADING_P (c1)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1398 src = src_base; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1399 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1400 { |
99074
10cd979d05ca
(make_conversion_work_buffer): Check that Vcode_conversion_reused_workbuf
Noah Friedman <friedman@splode.com>
parents:
98992
diff
changeset
|
1401 ONE_MORE_BYTE (c2); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1402 if (! UTF_8_EXTRA_OCTET_P (c2)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1403 src = src_base; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1404 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1405 { |
99074
10cd979d05ca
(make_conversion_work_buffer): Check that Vcode_conversion_reused_workbuf
Noah Friedman <friedman@splode.com>
parents:
98992
diff
changeset
|
1406 ONE_MORE_BYTE (c3); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1407 if (! UTF_8_EXTRA_OCTET_P (c3)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1408 src = src_base; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1409 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1410 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1411 if ((c1 != UTF_8_BOM_1) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1412 || (c2 != UTF_8_BOM_2) || (c3 != UTF_8_BOM_3)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1413 src = src_base; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1414 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1415 CODING_UTF_8_BOM (coding) = utf_without_bom; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1416 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1417 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1418 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1419 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1420 CODING_UTF_8_BOM (coding) = utf_without_bom; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1421 |
88365 | 1422 while (1) |
1423 { | |
1424 int c, c1, c2, c3, c4, c5; | |
1425 | |
1426 src_base = src; | |
1427 consumed_chars_base = consumed_chars; | |
1428 | |
1429 if (charbuf >= charbuf_end) | |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1430 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1431 if (byte_after_cr >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1432 src_base--; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1433 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1434 } |
88365 | 1435 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1436 if (byte_after_cr >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1437 c1 = byte_after_cr, byte_after_cr = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1438 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1439 ONE_MORE_BYTE (c1); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1440 if (c1 < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1441 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1442 c = - c1; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1443 } |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
1444 else if (UTF_8_1_OCTET_P (c1)) |
88365 | 1445 { |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1446 if (eol_crlf && c1 == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1447 ONE_MORE_BYTE (byte_after_cr); |
88365 | 1448 c = c1; |
1449 } | |
1450 else | |
1451 { | |
1452 ONE_MORE_BYTE (c2); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1453 if (c2 < 0 || ! UTF_8_EXTRA_OCTET_P (c2)) |
88365 | 1454 goto invalid_code; |
1455 if (UTF_8_2_OCTET_LEADING_P (c1)) | |
88669
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1456 { |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1457 c = ((c1 & 0x1F) << 6) | (c2 & 0x3F); |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1458 /* Reject overlong sequences here and below. Encoders |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1459 producing them are incorrect, they can be misleading, |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1460 and they mess up read/write invariance. */ |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1461 if (c < 128) |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1462 goto invalid_code; |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1463 } |
88365 | 1464 else |
1465 { | |
1466 ONE_MORE_BYTE (c3); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1467 if (c3 < 0 || ! UTF_8_EXTRA_OCTET_P (c3)) |
88365 | 1468 goto invalid_code; |
1469 if (UTF_8_3_OCTET_LEADING_P (c1)) | |
88669
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1470 { |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1471 c = (((c1 & 0xF) << 12) |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1472 | ((c2 & 0x3F) << 6) | (c3 & 0x3F)); |
89184
88a9e962e183
(decode_coding_utf_8): Treat surrogates as invalid.
Dave Love <fx@gnu.org>
parents:
89042
diff
changeset
|
1473 if (c < 0x800 |
88a9e962e183
(decode_coding_utf_8): Treat surrogates as invalid.
Dave Love <fx@gnu.org>
parents:
89042
diff
changeset
|
1474 || (c >= 0xd800 && c < 0xe000)) /* surrogates (invalid) */ |
88669
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1475 goto invalid_code; |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1476 } |
88365 | 1477 else |
1478 { | |
1479 ONE_MORE_BYTE (c4); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1480 if (c4 < 0 || ! UTF_8_EXTRA_OCTET_P (c4)) |
88365 | 1481 goto invalid_code; |
1482 if (UTF_8_4_OCTET_LEADING_P (c1)) | |
88669
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1483 { |
88365 | 1484 c = (((c1 & 0x7) << 18) | ((c2 & 0x3F) << 12) |
1485 | ((c3 & 0x3F) << 6) | (c4 & 0x3F)); | |
88669
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1486 if (c < 0x10000) |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1487 goto invalid_code; |
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1488 } |
88365 | 1489 else |
1490 { | |
1491 ONE_MORE_BYTE (c5); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1492 if (c5 < 0 || ! UTF_8_EXTRA_OCTET_P (c5)) |
88365 | 1493 goto invalid_code; |
1494 if (UTF_8_5_OCTET_LEADING_P (c1)) | |
1495 { | |
1496 c = (((c1 & 0x3) << 24) | ((c2 & 0x3F) << 18) | |
1497 | ((c3 & 0x3F) << 12) | ((c4 & 0x3F) << 6) | |
1498 | (c5 & 0x3F)); | |
88669
0bc5868f9f61
(decode_coding_utf_8): Reject overlong sequences.
Dave Love <fx@gnu.org>
parents:
88646
diff
changeset
|
1499 if ((c > MAX_CHAR) || (c < 0x200000)) |
88365 | 1500 goto invalid_code; |
1501 } | |
1502 else | |
1503 goto invalid_code; | |
1504 } | |
1505 } | |
1506 } | |
1507 } | |
1508 | |
1509 *charbuf++ = c; | |
1510 continue; | |
1511 | |
1512 invalid_code: | |
1513 src = src_base; | |
1514 consumed_chars = consumed_chars_base; | |
1515 ONE_MORE_BYTE (c); | |
1516 *charbuf++ = ASCII_BYTE_P (c) ? c : BYTE8_TO_CHAR (c); | |
1517 coding->errors++; | |
1518 } | |
1519 | |
1520 no_more_source: | |
1521 coding->consumed_char += consumed_chars_base; | |
1522 coding->consumed = src_base - coding->source; | |
1523 coding->charbuf_used = charbuf - coding->charbuf; | |
1524 } | |
1525 | |
1526 | |
1527 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1528 encode_coding_utf_8 (struct coding_system *coding) |
88365 | 1529 { |
1530 int multibytep = coding->dst_multibyte; | |
1531 int *charbuf = coding->charbuf; | |
1532 int *charbuf_end = charbuf + coding->charbuf_used; | |
1533 unsigned char *dst = coding->destination + coding->produced; | |
1534 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
1535 int produced_chars = 0; |
88365 | 1536 int c; |
1537 | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1538 if (CODING_UTF_8_BOM (coding) == utf_with_bom) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1539 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1540 ASSURE_DESTINATION (3); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1541 EMIT_THREE_BYTES (UTF_8_BOM_1, UTF_8_BOM_2, UTF_8_BOM_3); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1542 CODING_UTF_8_BOM (coding) = utf_without_bom; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1543 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1544 |
88365 | 1545 if (multibytep) |
1546 { | |
1547 int safe_room = MAX_MULTIBYTE_LENGTH * 2; | |
1548 | |
1549 while (charbuf < charbuf_end) | |
1550 { | |
1551 unsigned char str[MAX_MULTIBYTE_LENGTH], *p, *pend = str; | |
89483 | 1552 |
88365 | 1553 ASSURE_DESTINATION (safe_room); |
1554 c = *charbuf++; | |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1555 if (CHAR_BYTE8_P (c)) |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1556 { |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1557 c = CHAR_TO_BYTE8 (c); |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1558 EMIT_ONE_BYTE (c); |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1559 } |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1560 else |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1561 { |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1562 CHAR_STRING_ADVANCE_NO_UNIFY (c, pend); |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1563 for (p = str; p < pend; p++) |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1564 EMIT_ONE_BYTE (*p); |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
1565 } |
88365 | 1566 } |
1567 } | |
1568 else | |
1569 { | |
1570 int safe_room = MAX_MULTIBYTE_LENGTH; | |
1571 | |
1572 while (charbuf < charbuf_end) | |
1573 { | |
1574 ASSURE_DESTINATION (safe_room); | |
1575 c = *charbuf++; | |
89917
1763eef5ad02
(encode_coding_utf_8): Fix handling of raw-byte char.
Kenichi Handa <handa@m17n.org>
parents:
89905
diff
changeset
|
1576 if (CHAR_BYTE8_P (c)) |
1763eef5ad02
(encode_coding_utf_8): Fix handling of raw-byte char.
Kenichi Handa <handa@m17n.org>
parents:
89905
diff
changeset
|
1577 *dst++ = CHAR_TO_BYTE8 (c); |
1763eef5ad02
(encode_coding_utf_8): Fix handling of raw-byte char.
Kenichi Handa <handa@m17n.org>
parents:
89905
diff
changeset
|
1578 else |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
1579 CHAR_STRING_ADVANCE_NO_UNIFY (c, dst); |
88365 | 1580 produced_chars++; |
1581 } | |
1582 } | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1583 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 1584 coding->produced_char += produced_chars; |
1585 coding->produced = dst - coding->destination; | |
1586 return 0; | |
1587 } | |
1588 | |
1589 | |
1590 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1591 Check if a text is encoded in one of UTF-16 based coding systems. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1592 If it is, return 1, else return 0. */ |
88365 | 1593 |
1594 #define UTF_16_HIGH_SURROGATE_P(val) \ | |
1595 (((val) & 0xFC00) == 0xD800) | |
1596 | |
1597 #define UTF_16_LOW_SURROGATE_P(val) \ | |
1598 (((val) & 0xFC00) == 0xDC00) | |
1599 | |
1600 #define UTF_16_INVALID_P(val) \ | |
1601 (((val) == 0xFFFE) \ | |
1602 || ((val) == 0xFFFF) \ | |
1603 || UTF_16_LOW_SURROGATE_P (val)) | |
1604 | |
1605 | |
1606 static int | |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1607 detect_coding_utf_16 (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1608 struct coding_detection_info *detect_info) |
88365 | 1609 { |
111997
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
1610 const unsigned char *src = coding->source; |
89483 | 1611 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 1612 int multibytep = coding->src_multibyte; |
1613 int c1, c2; | |
1614 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1615 detect_info->checked |= CATEGORY_MASK_UTF_16; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1616 if (coding->mode & CODING_MODE_LAST_BLOCK |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1617 && (coding->src_chars & 1)) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1618 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1619 detect_info->rejected |= CATEGORY_MASK_UTF_16; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1620 return 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1621 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1622 |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1623 TWO_MORE_BYTES (c1, c2); |
88365 | 1624 if ((c1 == 0xFF) && (c2 == 0xFE)) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1625 { |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1626 detect_info->found |= (CATEGORY_MASK_UTF_16_LE |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1627 | CATEGORY_MASK_UTF_16_AUTO); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1628 detect_info->rejected |= (CATEGORY_MASK_UTF_16_BE |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1629 | CATEGORY_MASK_UTF_16_BE_NOSIG |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1630 | CATEGORY_MASK_UTF_16_LE_NOSIG); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1631 } |
88365 | 1632 else if ((c1 == 0xFE) && (c2 == 0xFF)) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1633 { |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1634 detect_info->found |= (CATEGORY_MASK_UTF_16_BE |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1635 | CATEGORY_MASK_UTF_16_AUTO); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1636 detect_info->rejected |= (CATEGORY_MASK_UTF_16_LE |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1637 | CATEGORY_MASK_UTF_16_BE_NOSIG |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1638 | CATEGORY_MASK_UTF_16_LE_NOSIG); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1639 } |
101174 | 1640 else if (c2 < 0) |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1641 { |
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1642 detect_info->rejected |= CATEGORY_MASK_UTF_16; |
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1643 return 0; |
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1644 } |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1645 else |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1646 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1647 /* We check the dispersion of Eth and Oth bytes where E is even and |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1648 O is odd. If both are high, we assume binary data.*/ |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1649 unsigned char e[256], o[256]; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1650 unsigned e_num = 1, o_num = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1651 |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1652 memset (e, 0, 256); |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1653 memset (o, 0, 256); |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1654 e[c1] = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1655 o[c2] = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1656 |
103442
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1657 detect_info->rejected |= (CATEGORY_MASK_UTF_16_AUTO |
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1658 |CATEGORY_MASK_UTF_16_BE |
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1659 | CATEGORY_MASK_UTF_16_LE); |
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1660 |
103448
73e7271dee09
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103442
diff
changeset
|
1661 while ((detect_info->rejected & CATEGORY_MASK_UTF_16) |
73e7271dee09
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103442
diff
changeset
|
1662 != CATEGORY_MASK_UTF_16) |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1663 { |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1664 TWO_MORE_BYTES (c1, c2); |
101174 | 1665 if (c2 < 0) |
101172
674e67257137
(TWO_MORE_BYTES): New macro.
Kenichi Handa <handa@m17n.org>
parents:
101040
diff
changeset
|
1666 break; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1667 if (! e[c1]) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1668 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1669 e[c1] = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1670 e_num++; |
103442
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1671 if (e_num >= 128) |
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1672 detect_info->rejected |= CATEGORY_MASK_UTF_16_BE_NOSIG; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1673 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1674 if (! o[c2]) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1675 { |
103435
45564d023acc
(detect_coding_utf_16): Fix typo counting odd bytes.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103306
diff
changeset
|
1676 o[c2] = 1; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1677 o_num++; |
103442
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1678 if (o_num >= 128) |
db4ec1a977bd
(detect_coding_utf_16): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
103441
diff
changeset
|
1679 detect_info->rejected |= CATEGORY_MASK_UTF_16_LE_NOSIG; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1680 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1681 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1682 return 0; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1683 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
1684 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
1685 no_more_source: |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
1686 return 1; |
88365 | 1687 } |
1688 | |
1689 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1690 decode_coding_utf_16 (struct coding_system *coding) |
88365 | 1691 { |
89483 | 1692 const unsigned char *src = coding->source + coding->consumed; |
1693 const unsigned char *src_end = coding->source + coding->src_bytes; | |
1694 const unsigned char *src_base; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
1695 int *charbuf = coding->charbuf + coding->charbuf_used; |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
1696 /* We may produces at most 3 chars in one loop. */ |
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
1697 int *charbuf_end = coding->charbuf + coding->charbuf_size - 2; |
100131
0e4115b39b5d
(decode_coding_utf_16): Initialize consumed_chars_base
Kenichi Handa <handa@m17n.org>
parents:
99753
diff
changeset
|
1698 int consumed_chars = 0, consumed_chars_base = 0; |
88365 | 1699 int multibytep = coding->src_multibyte; |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1700 enum utf_bom_type bom = CODING_UTF_16_BOM (coding); |
88365 | 1701 enum utf_16_endian_type endian = CODING_UTF_16_ENDIAN (coding); |
1702 int surrogate = CODING_UTF_16_SURROGATE (coding); | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1703 Lisp_Object attr, charset_list; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
1704 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
1705 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1706 int byte_after_cr1 = -1, byte_after_cr2 = -1; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1707 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1708 CODING_GET_INFO (coding, attr, charset_list); |
88365 | 1709 |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1710 if (bom == utf_with_bom) |
88365 | 1711 { |
1712 int c, c1, c2; | |
1713 | |
1714 src_base = src; | |
1715 ONE_MORE_BYTE (c1); | |
1716 ONE_MORE_BYTE (c2); | |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
1717 c = (c1 << 8) | c2; |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1718 |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1719 if (endian == utf_16_big_endian |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1720 ? c != 0xFEFF : c != 0xFFFE) |
88365 | 1721 { |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1722 /* The first two bytes are not BOM. Treat them as bytes |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1723 for a normal character. */ |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1724 src = src_base; |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1725 coding->errors++; |
88365 | 1726 } |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1727 CODING_UTF_16_BOM (coding) = utf_without_bom; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1728 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1729 else if (bom == utf_detect_bom) |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1730 { |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1731 /* We have already tried to detect BOM and failed in |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
1732 detect_coding. */ |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1733 CODING_UTF_16_BOM (coding) = utf_without_bom; |
88365 | 1734 } |
1735 | |
1736 while (1) | |
1737 { | |
1738 int c, c1, c2; | |
1739 | |
1740 src_base = src; | |
1741 consumed_chars_base = consumed_chars; | |
1742 | |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
1743 if (charbuf >= charbuf_end) |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1744 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1745 if (byte_after_cr1 >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1746 src_base -= 2; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1747 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
1748 } |
88365 | 1749 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1750 if (byte_after_cr1 >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1751 c1 = byte_after_cr1, byte_after_cr1 = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1752 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1753 ONE_MORE_BYTE (c1); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1754 if (c1 < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1755 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1756 *charbuf++ = -c1; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1757 continue; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1758 } |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1759 if (byte_after_cr2 >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1760 c2 = byte_after_cr2, byte_after_cr2 = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1761 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1762 ONE_MORE_BYTE (c2); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1763 if (c2 < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1764 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1765 *charbuf++ = ASCII_BYTE_P (c1) ? c1 : BYTE8_TO_CHAR (c1); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1766 *charbuf++ = -c2; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1767 continue; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1768 } |
88365 | 1769 c = (endian == utf_16_big_endian |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
1770 ? ((c1 << 8) | c2) : ((c2 << 8) | c1)); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1771 |
88365 | 1772 if (surrogate) |
1773 { | |
1774 if (! UTF_16_LOW_SURROGATE_P (c)) | |
1775 { | |
1776 if (endian == utf_16_big_endian) | |
1777 c1 = surrogate >> 8, c2 = surrogate & 0xFF; | |
1778 else | |
1779 c1 = surrogate & 0xFF, c2 = surrogate >> 8; | |
1780 *charbuf++ = c1; | |
1781 *charbuf++ = c2; | |
1782 coding->errors++; | |
1783 if (UTF_16_HIGH_SURROGATE_P (c)) | |
1784 CODING_UTF_16_SURROGATE (coding) = surrogate = c; | |
1785 else | |
1786 *charbuf++ = c; | |
1787 } | |
1788 else | |
1789 { | |
1790 c = ((surrogate - 0xD800) << 10) | (c - 0xDC00); | |
1791 CODING_UTF_16_SURROGATE (coding) = surrogate = 0; | |
89842
b5f22f538c1f
(decode_coding_utf_16): Fix handling of surrogate pare.
Kenichi Handa <handa@m17n.org>
parents:
89780
diff
changeset
|
1792 *charbuf++ = 0x10000 + c; |
88365 | 1793 } |
1794 } | |
1795 else | |
1796 { | |
1797 if (UTF_16_HIGH_SURROGATE_P (c)) | |
1798 CODING_UTF_16_SURROGATE (coding) = surrogate = c; | |
1799 else | |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1800 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1801 if (eol_crlf && c == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1802 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1803 ONE_MORE_BYTE (byte_after_cr1); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1804 ONE_MORE_BYTE (byte_after_cr2); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1805 } |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1806 *charbuf++ = c; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
1807 } |
89483 | 1808 } |
88365 | 1809 } |
1810 | |
1811 no_more_source: | |
1812 coding->consumed_char += consumed_chars_base; | |
1813 coding->consumed = src_base - coding->source; | |
1814 coding->charbuf_used = charbuf - coding->charbuf; | |
1815 } | |
1816 | |
1817 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
1818 encode_coding_utf_16 (struct coding_system *coding) |
88365 | 1819 { |
1820 int multibytep = coding->dst_multibyte; | |
1821 int *charbuf = coding->charbuf; | |
1822 int *charbuf_end = charbuf + coding->charbuf_used; | |
1823 unsigned char *dst = coding->destination + coding->produced; | |
1824 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
1825 int safe_room = 8; | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1826 enum utf_bom_type bom = CODING_UTF_16_BOM (coding); |
88365 | 1827 int big_endian = CODING_UTF_16_ENDIAN (coding) == utf_16_big_endian; |
1828 int produced_chars = 0; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1829 Lisp_Object attrs, charset_list; |
88365 | 1830 int c; |
1831 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
1832 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 1833 |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1834 if (bom != utf_without_bom) |
88365 | 1835 { |
1836 ASSURE_DESTINATION (safe_room); | |
1837 if (big_endian) | |
89404
3e1d187b52c3
(Qutf_16_be_nosig, Qutf_16_be, Qutf_16_le_nosig)
Kenichi Handa <handa@m17n.org>
parents:
89394
diff
changeset
|
1838 EMIT_TWO_BYTES (0xFE, 0xFF); |
88365 | 1839 else |
89404
3e1d187b52c3
(Qutf_16_be_nosig, Qutf_16_be, Qutf_16_le_nosig)
Kenichi Handa <handa@m17n.org>
parents:
89394
diff
changeset
|
1840 EMIT_TWO_BYTES (0xFF, 0xFE); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
1841 CODING_UTF_16_BOM (coding) = utf_without_bom; |
88365 | 1842 } |
1843 | |
1844 while (charbuf < charbuf_end) | |
1845 { | |
1846 ASSURE_DESTINATION (safe_room); | |
1847 c = *charbuf++; | |
104636
bc74846b9a54
(encode_coding_utf_16): Fix checking of an Unicode character.
Kenichi Handa <handa@m17n.org>
parents:
103762
diff
changeset
|
1848 if (c > MAX_UNICODE_CHAR) |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
1849 c = coding->default_char; |
88365 | 1850 |
1851 if (c < 0x10000) | |
1852 { | |
1853 if (big_endian) | |
1854 EMIT_TWO_BYTES (c >> 8, c & 0xFF); | |
1855 else | |
1856 EMIT_TWO_BYTES (c & 0xFF, c >> 8); | |
1857 } | |
1858 else | |
1859 { | |
1860 int c1, c2; | |
1861 | |
1862 c -= 0x10000; | |
1863 c1 = (c >> 10) + 0xD800; | |
1864 c2 = (c & 0x3FF) + 0xDC00; | |
1865 if (big_endian) | |
1866 EMIT_FOUR_BYTES (c1 >> 8, c1 & 0xFF, c2 >> 8, c2 & 0xFF); | |
1867 else | |
1868 EMIT_FOUR_BYTES (c1 & 0xFF, c1 >> 8, c2 & 0xFF, c2 >> 8); | |
1869 } | |
1870 } | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
1871 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 1872 coding->produced = dst - coding->destination; |
1873 coding->produced_char += produced_chars; | |
1874 return 0; | |
1875 } | |
1876 | |
1877 | |
1878 /*** 6. Old Emacs' internal format (emacs-mule) ***/ | |
17052 | 1879 |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1880 /* Emacs' internal format for representation of multiple character |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1881 sets is a kind of multi-byte encoding, i.e. characters are |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1882 represented by variable-length sequences of one-byte codes. |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1883 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1884 ASCII characters and control characters (e.g. `tab', `newline') are |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1885 represented by one-byte sequences which are their ASCII codes, in |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1886 the range 0x00 through 0x7F. |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1887 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1888 8-bit characters of the range 0x80..0x9F are represented by |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1889 two-byte sequences of LEADING_CODE_8_BIT_CONTROL and (their 8-bit |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1890 code + 0x20). |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1891 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1892 8-bit characters of the range 0xA0..0xFF are represented by |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1893 one-byte sequences which are their 8-bit code. |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1894 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1895 The other characters are represented by a sequence of `base |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1896 leading-code', optional `extended leading-code', and one or two |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1897 `position-code's. The length of the sequence is determined by the |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1898 base leading-code. Leading-code takes the range 0x81 through 0x9D, |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1899 whereas extended leading-code and position-code take the range 0xA0 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1900 through 0xFF. See `charset.h' for more details about leading-code |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1901 and position-code. |
18766 | 1902 |
17052 | 1903 --- CODE RANGE of Emacs' internal format --- |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1904 character set range |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1905 ------------- ----- |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1906 ascii 0x00..0x7F |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1907 eight-bit-control LEADING_CODE_8_BIT_CONTROL + 0xA0..0xBF |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
1908 eight-bit-graphic 0xA0..0xBF |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1909 ELSE 0x81..0x9D + [0xA0..0xFF]+ |
17052 | 1910 --------------------------------------------- |
1911 | |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1912 As this is the internal character representation, the format is |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1913 usually not used externally (i.e. in a file or in a data sent to a |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1914 process). But, it is possible to have a text externally in this |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1915 format (i.e. by encoding by the coding system `emacs-mule'). |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1916 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1917 In that case, a sequence of one-byte codes has a slightly different |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1918 form. |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1919 |
88365 | 1920 At first, all characters in eight-bit-control are represented by |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1921 one-byte sequences which are their 8-bit code. |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1922 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1923 Next, character composition data are represented by the byte |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1924 sequence of the form: 0x80 METHOD BYTES CHARS COMPONENT ..., |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1925 where, |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1926 METHOD is 0xF2 plus one of composition method (enum |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1927 composition_method), |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1928 |
88365 | 1929 BYTES is 0xA0 plus a byte length of this composition data, |
1930 | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1931 CHARS is 0xA0 plus a number of characters composed by this |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1932 data, |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1933 |
110983 | 1934 COMPONENTs are characters of multibyte form or composition |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1935 rules encoded by two-byte of ASCII codes. |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1936 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1937 In addition, for backward compatibility, the following formats are |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1938 also recognized as composition data on decoding. |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1939 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1940 0x80 MSEQ ... |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1941 0x80 0xFF MSEQ RULE MSEQ RULE ... MSEQ |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1942 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1943 Here, |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1944 MSEQ is a multibyte form but in these special format: |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1945 ASCII: 0xA0 ASCII_CODE+0x80, |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1946 other: LEADING_CODE+0x20 FOLLOWING-BYTE ..., |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1947 RULE is a one byte code of the range 0xA0..0xF0 that |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
1948 represents a composition rule. |
17052 | 1949 */ |
1950 | |
88365 | 1951 char emacs_mule_bytes[256]; |
1952 | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1953 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1954 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1955 Check if a text is encoded in `emacs-mule'. If it is, return 1, |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1956 else return 0. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1957 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1958 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1959 detect_coding_emacs_mule (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
1960 struct coding_detection_info *detect_info) |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1961 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1962 const unsigned char *src = coding->source, *src_base; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1963 const unsigned char *src_end = coding->source + coding->src_bytes; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1964 int multibytep = coding->src_multibyte; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1965 int consumed_chars = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1966 int c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1967 int found = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1968 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1969 detect_info->checked |= CATEGORY_MASK_EMACS_MULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1970 /* A coding system of this category is always ASCII compatible. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1971 src += coding->head_ascii; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1972 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1973 while (1) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1974 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1975 src_base = src; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1976 ONE_MORE_BYTE (c); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1977 if (c < 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1978 continue; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1979 if (c == 0x80) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1980 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1981 /* Perhaps the start of composite character. We simply skip |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1982 it because analyzing it is too heavy for detecting. But, |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1983 at least, we check that the composite character |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1984 constitutes of more than 4 bytes. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1985 const unsigned char *src_base; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1986 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1987 repeat: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1988 src_base = src; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1989 do |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1990 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1991 ONE_MORE_BYTE (c); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1992 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1993 while (c >= 0xA0); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1994 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1995 if (src - src_base <= 4) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1996 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1997 found = CATEGORY_MASK_EMACS_MULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1998 if (c == 0x80) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
1999 goto repeat; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2000 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2001 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2002 if (c < 0x80) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2003 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2004 if (c < 0x20 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2005 && (c == ISO_CODE_ESC || c == ISO_CODE_SI || c == ISO_CODE_SO)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2006 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2007 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2008 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2009 { |
110334
4ad4f097835e
coding.c (detect_coding_emacs_mule): Fix checking of multibyte sequence when the source is multibyte.
Kenichi Handa <handa@m17n.org>
parents:
109710
diff
changeset
|
2010 int more_bytes = emacs_mule_bytes[c] - 1; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2011 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2012 while (more_bytes > 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2013 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2014 ONE_MORE_BYTE (c); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2015 if (c < 0xA0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2016 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2017 src--; /* Unread the last byte. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2018 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2019 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2020 more_bytes--; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2021 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2022 if (more_bytes != 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2023 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2024 found = CATEGORY_MASK_EMACS_MULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2025 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2026 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2027 detect_info->rejected |= CATEGORY_MASK_EMACS_MULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2028 return 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2029 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2030 no_more_source: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2031 if (src_base < src && coding->mode & CODING_MODE_LAST_BLOCK) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2032 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2033 detect_info->rejected |= CATEGORY_MASK_EMACS_MULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2034 return 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2035 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2036 detect_info->found |= found; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2037 return 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2038 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2039 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2040 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2041 /* Parse emacs-mule multibyte sequence at SRC and return the decoded |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2042 character. If CMP_STATUS indicates that we must expect MSEQ or |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2043 RULE described above, decode it and return the negative value of |
107323
ebc10ed88b5c
(emacs_mule_char): Fix a typo in commentary.
Eli Zaretskii <eliz@gnu.org>
parents:
107321
diff
changeset
|
2044 the decoded character or rule. If an invalid byte is found, return |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2045 -1. If SRC is too short, return -2. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2046 |
88365 | 2047 int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
2048 emacs_mule_char (struct coding_system *coding, const unsigned char *src, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
2049 int *nbytes, int *nchars, int *id, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
2050 struct composition_status *cmp_status) |
88365 | 2051 { |
89483 | 2052 const unsigned char *src_end = coding->source + coding->src_bytes; |
2053 const unsigned char *src_base = src; | |
88365 | 2054 int multibytep = coding->src_multibyte; |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2055 int charset_id; |
88365 | 2056 unsigned code; |
2057 int c; | |
2058 int consumed_chars = 0; | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2059 int mseq_found = 0; |
88365 | 2060 |
2061 ONE_MORE_BYTE (c); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2062 if (c < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2063 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2064 c = -c; |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2065 charset_id = emacs_mule_charset[0]; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2066 } |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2067 else |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2068 { |
90354
450fb16a4bf4
(DECODE_COMPOSITION_START): If the source is short, set
Kenichi Handa <handa@m17n.org>
parents:
90350
diff
changeset
|
2069 if (c >= 0xA0) |
450fb16a4bf4
(DECODE_COMPOSITION_START): If the source is short, set
Kenichi Handa <handa@m17n.org>
parents:
90350
diff
changeset
|
2070 { |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2071 if (cmp_status->state != COMPOSING_NO |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2072 && cmp_status->old_form) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2073 { |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2074 if (cmp_status->state == COMPOSING_CHAR) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2075 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2076 if (c == 0xA0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2077 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2078 ONE_MORE_BYTE (c); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2079 c -= 0x80; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2080 if (c < 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2081 goto invalid_code; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2082 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2083 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2084 c -= 0x20; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2085 mseq_found = 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2086 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2087 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2088 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2089 *nbytes = src - src_base; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2090 *nchars = consumed_chars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2091 return -c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2092 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2093 } |
17052 | 2094 else |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2095 goto invalid_code; |
17052 | 2096 } |
2097 | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2098 switch (emacs_mule_bytes[c]) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2099 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2100 case 2: |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2101 if ((charset_id = emacs_mule_charset[c]) < 0) |
88365 | 2102 goto invalid_code; |
2103 ONE_MORE_BYTE (c); | |
17052 | 2104 if (c < 0xA0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2105 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2106 code = c & 0x7F; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2107 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2108 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2109 case 3: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2110 if (c == EMACS_MULE_LEADING_CODE_PRIVATE_11 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2111 || c == EMACS_MULE_LEADING_CODE_PRIVATE_12) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2112 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2113 ONE_MORE_BYTE (c); |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2114 if (c < 0xA0 || (charset_id = emacs_mule_charset[c]) < 0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2115 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2116 ONE_MORE_BYTE (c); |
89892 | 2117 if (c < 0xA0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2118 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2119 code = c & 0x7F; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2120 } |
26847 | 2121 else |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2122 { |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2123 if ((charset_id = emacs_mule_charset[c]) < 0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2124 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2125 ONE_MORE_BYTE (c); |
89892 | 2126 if (c < 0xA0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2127 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2128 code = (c & 0x7F) << 8; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2129 ONE_MORE_BYTE (c); |
89892 | 2130 if (c < 0xA0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2131 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2132 code |= c & 0x7F; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2133 } |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2134 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2135 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2136 case 4: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2137 ONE_MORE_BYTE (c); |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2138 if (c < 0 || (charset_id = emacs_mule_charset[c]) < 0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2139 goto invalid_code; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2140 ONE_MORE_BYTE (c); |
89892 | 2141 if (c < 0xA0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2142 goto invalid_code; |
88585
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
2143 code = (c & 0x7F) << 8; |
88365 | 2144 ONE_MORE_BYTE (c); |
89892 | 2145 if (c < 0xA0) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2146 goto invalid_code; |
88365 | 2147 code |= c & 0x7F; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2148 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2149 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2150 case 1: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2151 code = c; |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2152 charset_id = ASCII_BYTE_P (code) ? charset_ascii : charset_eight_bit; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2153 break; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2154 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2155 default: |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2156 abort (); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2157 } |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2158 CODING_DECODE_CHAR (coding, src, src_base, src_end, |
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2159 CHARSET_FROM_ID (charset_id), code, c); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2160 if (c < 0) |
88365 | 2161 goto invalid_code; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2162 } |
88365 | 2163 *nbytes = src - src_base; |
2164 *nchars = consumed_chars; | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2165 if (id) |
111743
913b779aa4ee
Fix decoding of emacs-mule coding system.
Kenichi Handa <handa@m17n.org>
parents:
110983
diff
changeset
|
2166 *id = charset_id; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2167 return (mseq_found ? -c : c); |
88365 | 2168 |
2169 no_more_source: | |
2170 return -2; | |
2171 | |
2172 invalid_code: | |
2173 return -1; | |
2174 } | |
2175 | |
17052 | 2176 |
88365 | 2177 /* See the above "GENERAL NOTES on `decode_coding_XXX ()' functions". */ |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2178 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2179 /* Handle these composition sequence ('|': the end of header elements, |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2180 BYTES and CHARS >= 0xA0): |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2181 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2182 (1) relative composition: 0x80 0xF2 BYTES CHARS | CHAR ... |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2183 (2) altchar composition: 0x80 0xF4 BYTES CHARS | ALT ... ALT CHAR ... |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2184 (3) alt&rule composition: 0x80 0xF5 BYTES CHARS | ALT RULE ... ALT CHAR ... |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2185 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2186 and these old form: |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
2187 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2188 (4) relative composition: 0x80 | MSEQ ... MSEQ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2189 (5) rulebase composition: 0x80 0xFF | MSEQ MRULE ... MSEQ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2190 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2191 When the starter 0x80 and the following header elements are found, |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2192 this annotation header is produced. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2193 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2194 [ -LENGTH(==-5) CODING_ANNOTATE_COMPOSITION_MASK NCHARS NBYTES METHOD ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2195 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2196 NCHARS is CHARS - 0xA0 for (1), (2), (3), and 0 for (4), (5). |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2197 NBYTES is BYTES - 0xA0 for (1), (2), (3), and 0 for (4), (5). |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2198 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2199 Then, upon reading the following elements, these codes are produced |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2200 until the composition end is found: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2201 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2202 (1) CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2203 (2) ALT ... ALT CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2204 (3) ALT -2 DECODED-RULE ALT -2 DECODED-RULE ... ALT CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2205 (4) CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2206 (5) CHAR -2 DECODED-RULE CHAR -2 DECODED-RULE ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2207 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2208 When the composition end is found, LENGTH and NCHARS in the |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2209 annotation header is updated as below: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2210 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2211 (1) LENGTH: unchanged, NCHARS: unchanged |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2212 (2) LENGTH: length of the whole sequence minus NCHARS, NCHARS: unchanged |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2213 (3) LENGTH: length of the whole sequence minus NCHARS, NCHARS: unchanged |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2214 (4) LENGTH: unchanged, NCHARS: number of CHARs |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2215 (5) LENGTH: unchanged, NCHARS: number of CHARs |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2216 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2217 If an error is found while composing, the annotation header is |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2218 changed to the original composition header (plus filler -1s) as |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2219 below: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2220 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2221 (1),(2),(3) [ 0x80 0xF2+METHOD BYTES CHARS -1 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2222 (5) [ 0x80 0xFF -1 -1- -1 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2223 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2224 and the sequence [ -2 DECODED-RULE ] is changed to the original |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2225 byte sequence as below: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2226 o the original byte sequence is B: [ B -1 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2227 o the original byte sequence is B1 B2: [ B1 B2 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2228 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2229 Most of the routines are implemented by macros because many |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2230 variables and labels in the caller decode_coding_emacs_mule must be |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2231 accessible, and they are usually called just once (thus doesn't |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2232 increase the size of compiled object). */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2233 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2234 /* Decode a composition rule represented by C as a component of |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2235 composition sequence of Emacs 20 style. Set RULE to the decoded |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2236 rule. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2237 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2238 #define DECODE_EMACS_MULE_COMPOSITION_RULE_20(c, rule) \ |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2239 do { \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2240 int gref, nref; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2241 \ |
90354
450fb16a4bf4
(DECODE_COMPOSITION_START): If the source is short, set
Kenichi Handa <handa@m17n.org>
parents:
90350
diff
changeset
|
2242 c -= 0xA0; \ |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2243 if (c < 0 || c >= 81) \ |
88365 | 2244 goto invalid_code; \ |
2245 gref = c / 9, nref = c % 9; \ | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2246 if (gref == 4) gref = 10; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2247 if (nref == 4) nref = 10; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2248 rule = COMPOSITION_ENCODE_RULE (gref, nref); \ |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2249 } while (0) |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2250 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2251 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2252 /* Decode a composition rule represented by C and the following byte |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2253 at SRC as a component of composition sequence of Emacs 21 style. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2254 Set RULE to the decoded rule. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2255 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2256 #define DECODE_EMACS_MULE_COMPOSITION_RULE_21(c, rule) \ |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2257 do { \ |
88585
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
2258 int gref, nref; \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2259 \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2260 gref = c - 0x20; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2261 if (gref < 0 || gref >= 81) \ |
88585
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
2262 goto invalid_code; \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2263 ONE_MORE_BYTE (c); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2264 nref = c - 0x20; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2265 if (nref < 0 || nref >= 81) \ |
88585
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
2266 goto invalid_code; \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2267 rule = COMPOSITION_ENCODE_RULE (gref, nref); \ |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2268 } while (0) |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2269 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2270 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2271 /* Start of Emacs 21 style format. The first three bytes at SRC are |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2272 (METHOD - 0xF2), (BYTES - 0xA0), (CHARS - 0xA0), where BYTES is the |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2273 byte length of this composition information, CHARS is the number of |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2274 characters composed by this composition. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2275 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2276 #define DECODE_EMACS_MULE_21_COMPOSITION() \ |
88365 | 2277 do { \ |
88585
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
2278 enum composition_method method = c - 0xF2; \ |
88365 | 2279 int nbytes, nchars; \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2280 \ |
88365 | 2281 ONE_MORE_BYTE (c); \ |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2282 if (c < 0) \ |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2283 goto invalid_code; \ |
88365 | 2284 nbytes = c - 0xA0; \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2285 if (nbytes < 3 || (method == COMPOSITION_RELATIVE && nbytes != 4)) \ |
88365 | 2286 goto invalid_code; \ |
2287 ONE_MORE_BYTE (c); \ | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2288 nchars = c - 0xA0; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2289 if (nchars <= 0 || nchars >= MAX_COMPOSITION_COMPONENTS) \ |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2290 goto invalid_code; \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2291 cmp_status->old_form = 0; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2292 cmp_status->method = method; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2293 if (method == COMPOSITION_RELATIVE) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2294 cmp_status->state = COMPOSING_CHAR; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2295 else \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2296 cmp_status->state = COMPOSING_COMPONENT_CHAR; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2297 cmp_status->length = MAX_ANNOTATION_LENGTH; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2298 cmp_status->nchars = nchars; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2299 cmp_status->ncomps = nbytes - 4; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2300 ADD_COMPOSITION_DATA (charbuf, nchars, nbytes, method); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2301 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2302 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2303 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2304 /* Start of Emacs 20 style format for relative composition. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2305 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2306 #define DECODE_EMACS_MULE_20_RELATIVE_COMPOSITION() \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2307 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2308 cmp_status->old_form = 1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2309 cmp_status->method = COMPOSITION_RELATIVE; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2310 cmp_status->state = COMPOSING_CHAR; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2311 cmp_status->length = MAX_ANNOTATION_LENGTH; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2312 cmp_status->nchars = cmp_status->ncomps = 0; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2313 ADD_COMPOSITION_DATA (charbuf, 0, 0, cmp_status->method); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2314 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2315 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2316 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2317 /* Start of Emacs 20 style format for rule-base composition. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2318 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2319 #define DECODE_EMACS_MULE_20_RULEBASE_COMPOSITION() \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2320 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2321 cmp_status->old_form = 1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2322 cmp_status->method = COMPOSITION_WITH_RULE; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2323 cmp_status->state = COMPOSING_CHAR; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2324 cmp_status->length = MAX_ANNOTATION_LENGTH; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2325 cmp_status->nchars = cmp_status->ncomps = 0; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2326 ADD_COMPOSITION_DATA (charbuf, 0, 0, cmp_status->method); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2327 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2328 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2329 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2330 #define DECODE_EMACS_MULE_COMPOSITION_START() \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2331 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2332 const unsigned char *current_src = src; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2333 \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2334 ONE_MORE_BYTE (c); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2335 if (c < 0) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2336 goto invalid_code; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2337 if (c - 0xF2 >= COMPOSITION_RELATIVE \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2338 && c - 0xF2 <= COMPOSITION_WITH_RULE_ALTCHARS) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2339 DECODE_EMACS_MULE_21_COMPOSITION (); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2340 else if (c < 0xA0) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2341 goto invalid_code; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2342 else if (c < 0xC0) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2343 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2344 DECODE_EMACS_MULE_20_RELATIVE_COMPOSITION (); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2345 /* Re-read C as a composition component. */ \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2346 src = current_src; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2347 } \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2348 else if (c == 0xFF) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2349 DECODE_EMACS_MULE_20_RULEBASE_COMPOSITION (); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2350 else \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2351 goto invalid_code; \ |
88365 | 2352 } while (0) |
2353 | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2354 #define EMACS_MULE_COMPOSITION_END() \ |
88365 | 2355 do { \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2356 int idx = - cmp_status->length; \ |
90354
450fb16a4bf4
(DECODE_COMPOSITION_START): If the source is short, set
Kenichi Handa <handa@m17n.org>
parents:
90350
diff
changeset
|
2357 \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2358 if (cmp_status->old_form) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2359 charbuf[idx + 2] = cmp_status->nchars; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2360 else if (cmp_status->method > COMPOSITION_RELATIVE) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2361 charbuf[idx] = charbuf[idx + 2] - cmp_status->length; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2362 cmp_status->state = COMPOSING_NO; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2363 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2364 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2365 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2366 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
2367 emacs_mule_finish_composition (int *charbuf, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
2368 struct composition_status *cmp_status) |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2369 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2370 int idx = - cmp_status->length; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2371 int new_chars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2372 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2373 if (cmp_status->old_form && cmp_status->nchars > 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2374 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2375 charbuf[idx + 2] = cmp_status->nchars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2376 new_chars = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2377 if (cmp_status->method == COMPOSITION_WITH_RULE |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2378 && cmp_status->state == COMPOSING_CHAR) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2379 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2380 /* The last rule was invalid. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2381 int rule = charbuf[-1] + 0xA0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2382 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2383 charbuf[-2] = BYTE8_TO_CHAR (rule); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2384 charbuf[-1] = -1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2385 new_chars = 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2386 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2387 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2388 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2389 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2390 charbuf[idx++] = BYTE8_TO_CHAR (0x80); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2391 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2392 if (cmp_status->method == COMPOSITION_WITH_RULE) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2393 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2394 charbuf[idx++] = BYTE8_TO_CHAR (0xFF); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2395 charbuf[idx++] = -3; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2396 charbuf[idx++] = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2397 new_chars = 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2398 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2399 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2400 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2401 int nchars = charbuf[idx + 1] + 0xA0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2402 int nbytes = charbuf[idx + 2] + 0xA0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2403 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2404 charbuf[idx++] = BYTE8_TO_CHAR (0xF2 + cmp_status->method); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2405 charbuf[idx++] = BYTE8_TO_CHAR (nbytes); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2406 charbuf[idx++] = BYTE8_TO_CHAR (nchars); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2407 charbuf[idx++] = -1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2408 new_chars = 4; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2409 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2410 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2411 cmp_status->state = COMPOSING_NO; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2412 return new_chars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2413 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2414 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2415 #define EMACS_MULE_MAYBE_FINISH_COMPOSITION() \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2416 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2417 if (cmp_status->state != COMPOSING_NO) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2418 char_offset += emacs_mule_finish_composition (charbuf, cmp_status); \ |
88365 | 2419 } while (0) |
2420 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2421 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2422 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
2423 decode_coding_emacs_mule (struct coding_system *coding) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2424 { |
89483 | 2425 const unsigned char *src = coding->source + coding->consumed; |
2426 const unsigned char *src_end = coding->source + coding->src_bytes; | |
59168
0345f2b10f1d
(decode_coding_XXX, decode_composition_emacs_mule)
Dan Nicolaescu <dann@ics.uci.edu>
parents:
59095
diff
changeset
|
2427 const unsigned char *src_base; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
2428 int *charbuf = coding->charbuf + coding->charbuf_used; |
110983 | 2429 /* We may produce two annotations (charset and composition) in one |
2430 loop and one more charset annotation at the end. */ | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
2431 int *charbuf_end |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
2432 = coding->charbuf + coding->charbuf_size - (MAX_ANNOTATION_LENGTH * 3); |
88365 | 2433 int consumed_chars = 0, consumed_chars_base; |
2434 int multibytep = coding->src_multibyte; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
2435 Lisp_Object attrs, charset_list; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2436 int char_offset = coding->produced_char; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2437 int last_offset = char_offset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2438 int last_id = charset_ascii; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
2439 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
2440 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2441 int byte_after_cr = -1; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2442 struct composition_status *cmp_status = &coding->spec.emacs_mule.cmp_status; |
88365 | 2443 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
2444 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 2445 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2446 if (cmp_status->state != COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2447 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2448 int i; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2449 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2450 for (i = 0; i < cmp_status->length; i++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2451 *charbuf++ = cmp_status->carryover[i]; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2452 coding->annotated = 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2453 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2454 |
88365 | 2455 while (1) |
2456 { | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2457 int c, id; |
88365 | 2458 |
2459 src_base = src; | |
2460 consumed_chars_base = consumed_chars; | |
2461 | |
2462 if (charbuf >= charbuf_end) | |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
2463 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
2464 if (byte_after_cr >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
2465 src_base--; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
2466 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
2467 } |
88365 | 2468 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2469 if (byte_after_cr >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2470 c = byte_after_cr, byte_after_cr = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2471 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2472 ONE_MORE_BYTE (c); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2473 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2474 if (c < 0 || c == 0x80) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2475 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2476 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2477 if (c < 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2478 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2479 *charbuf++ = -c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2480 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2481 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2482 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2483 DECODE_EMACS_MULE_COMPOSITION_START (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2484 continue; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2485 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2486 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2487 if (c < 0x80) |
32806
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2488 { |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2489 if (eol_crlf && c == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
2490 ONE_MORE_BYTE (byte_after_cr); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2491 id = charset_ascii; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2492 if (cmp_status->state != COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2493 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2494 if (cmp_status->old_form) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2495 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2496 else if (cmp_status->state >= COMPOSING_COMPONENT_CHAR) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2497 cmp_status->ncomps--; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2498 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2499 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2500 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2501 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2502 int nchars, nbytes; |
107321
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2503 /* emacs_mule_char can load a charset map from a file, which |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2504 allocates a large structure and might cause buffer text |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2505 to be relocated as result. Thus, we need to remember the |
110983 | 2506 original pointer to buffer text, and fix up all related |
107321
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2507 pointers after the call. */ |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2508 const unsigned char *orig = coding->source; |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2509 EMACS_INT offset; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2510 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2511 c = emacs_mule_char (coding, src_base, &nbytes, &nchars, &id, |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2512 cmp_status); |
107321
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2513 offset = coding->source - orig; |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2514 if (offset) |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2515 { |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2516 src += offset; |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2517 src_base += offset; |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2518 src_end += offset; |
9b814b3ee348
Fix bug in decoding emacs-mule encoding.
Eli Zaretskii <eliz@gnu.org>
parents:
107174
diff
changeset
|
2519 } |
88365 | 2520 if (c < 0) |
32806
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2521 { |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2522 if (c == -1) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2523 goto invalid_code; |
88365 | 2524 if (c == -2) |
2525 break; | |
32806
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2526 } |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2527 src = src_base + nbytes; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2528 consumed_chars = consumed_chars_base + nchars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2529 if (cmp_status->state >= COMPOSING_COMPONENT_CHAR) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2530 cmp_status->ncomps -= nchars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2531 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2532 |
110983 | 2533 /* Now if C >= 0, we found a normally encoded character, if C < |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2534 0, we found an old-style composition component character or |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2535 rule. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2536 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2537 if (cmp_status->state == COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2538 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2539 if (last_id != id) |
32806
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2540 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2541 if (last_id != charset_ascii) |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2542 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2543 last_id); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2544 last_id = id; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2545 last_offset = char_offset; |
32806
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2546 } |
88365 | 2547 *charbuf++ = c; |
2548 char_offset++; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2549 } |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2550 else if (cmp_status->state == COMPOSING_CHAR) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2551 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2552 if (cmp_status->old_form) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2553 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2554 if (c >= 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2555 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2556 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2557 *charbuf++ = c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2558 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2559 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2560 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2561 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2562 *charbuf++ = -c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2563 cmp_status->nchars++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2564 cmp_status->length++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2565 if (cmp_status->nchars == MAX_COMPOSITION_COMPONENTS) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2566 EMACS_MULE_COMPOSITION_END (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2567 else if (cmp_status->method == COMPOSITION_WITH_RULE) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2568 cmp_status->state = COMPOSING_RULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2569 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2570 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2571 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2572 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2573 *charbuf++ = c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2574 cmp_status->length++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2575 cmp_status->nchars--; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2576 if (cmp_status->nchars == 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2577 EMACS_MULE_COMPOSITION_END (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2578 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2579 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2580 else if (cmp_status->state == COMPOSING_RULE) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2581 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2582 int rule; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2583 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2584 if (c >= 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2585 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2586 EMACS_MULE_COMPOSITION_END (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2587 *charbuf++ = c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2588 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2589 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2590 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2591 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2592 c = -c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2593 DECODE_EMACS_MULE_COMPOSITION_RULE_20 (c, rule); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2594 if (rule < 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2595 goto invalid_code; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2596 *charbuf++ = -2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2597 *charbuf++ = rule; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2598 cmp_status->length += 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2599 cmp_status->state = COMPOSING_CHAR; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2600 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2601 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2602 else if (cmp_status->state == COMPOSING_COMPONENT_CHAR) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2603 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2604 *charbuf++ = c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2605 cmp_status->length++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2606 if (cmp_status->ncomps == 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2607 cmp_status->state = COMPOSING_CHAR; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2608 else if (cmp_status->ncomps > 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2609 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2610 if (cmp_status->method == COMPOSITION_WITH_RULE_ALTCHARS) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2611 cmp_status->state = COMPOSING_COMPONENT_RULE; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2612 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2613 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2614 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2615 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2616 else /* COMPOSING_COMPONENT_RULE */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2617 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2618 int rule; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2619 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2620 DECODE_EMACS_MULE_COMPOSITION_RULE_21 (c, rule); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2621 if (rule < 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2622 goto invalid_code; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2623 *charbuf++ = -2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2624 *charbuf++ = rule; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2625 cmp_status->length += 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2626 cmp_status->ncomps--; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2627 if (cmp_status->ncomps > 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2628 cmp_status->state = COMPOSING_COMPONENT_CHAR; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2629 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2630 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2631 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2632 continue; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2633 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2634 src = src_base; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2635 consumed_chars = consumed_chars_base; |
88365 | 2636 continue; |
2637 | |
2638 invalid_code: | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2639 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
88365 | 2640 src = src_base; |
2641 consumed_chars = consumed_chars_base; | |
2642 ONE_MORE_BYTE (c); | |
2643 *charbuf++ = ASCII_BYTE_P (c) ? c : BYTE8_TO_CHAR (c); | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2644 char_offset++; |
88365 | 2645 coding->errors++; |
2646 } | |
2647 | |
2648 no_more_source: | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2649 if (cmp_status->state != COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2650 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2651 if (coding->mode & CODING_MODE_LAST_BLOCK) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2652 EMACS_MULE_MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2653 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2654 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2655 int i; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2656 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2657 charbuf -= cmp_status->length; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2658 for (i = 0; i < cmp_status->length; i++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2659 cmp_status->carryover[i] = charbuf[i]; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2660 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
2661 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2662 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
2663 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
88365 | 2664 coding->consumed_char += consumed_chars_base; |
2665 coding->consumed = src_base - coding->source; | |
2666 coding->charbuf_used = charbuf - coding->charbuf; | |
2667 } | |
2668 | |
2669 | |
2670 #define EMACS_MULE_LEADING_CODES(id, codes) \ | |
2671 do { \ | |
2672 if (id < 0xA0) \ | |
2673 codes[0] = id, codes[1] = 0; \ | |
2674 else if (id < 0xE0) \ | |
2675 codes[0] = 0x9A, codes[1] = id; \ | |
2676 else if (id < 0xF0) \ | |
2677 codes[0] = 0x9B, codes[1] = id; \ | |
2678 else if (id < 0xF5) \ | |
2679 codes[0] = 0x9C, codes[1] = id; \ | |
2680 else \ | |
2681 codes[0] = 0x9D, codes[1] = id; \ | |
2682 } while (0); | |
2683 | |
2684 | |
2685 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
2686 encode_coding_emacs_mule (struct coding_system *coding) |
88365 | 2687 { |
2688 int multibytep = coding->dst_multibyte; | |
2689 int *charbuf = coding->charbuf; | |
2690 int *charbuf_end = charbuf + coding->charbuf_used; | |
2691 unsigned char *dst = coding->destination + coding->produced; | |
2692 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
2693 int safe_room = 8; | |
2694 int produced_chars = 0; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
2695 Lisp_Object attrs, charset_list; |
88365 | 2696 int c; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2697 int preferred_charset_id = -1; |
88365 | 2698 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
2699 CODING_GET_INFO (coding, attrs, charset_list); |
89644
fc9cda144ffc
(encode_coding_emacs_mule): Resync charset_list to
Kenichi Handa <handa@m17n.org>
parents:
89642
diff
changeset
|
2700 if (! EQ (charset_list, Vemacs_mule_charset_list)) |
fc9cda144ffc
(encode_coding_emacs_mule): Resync charset_list to
Kenichi Handa <handa@m17n.org>
parents:
89642
diff
changeset
|
2701 { |
fc9cda144ffc
(encode_coding_emacs_mule): Resync charset_list to
Kenichi Handa <handa@m17n.org>
parents:
89642
diff
changeset
|
2702 CODING_ATTR_CHARSET_LIST (attrs) |
fc9cda144ffc
(encode_coding_emacs_mule): Resync charset_list to
Kenichi Handa <handa@m17n.org>
parents:
89642
diff
changeset
|
2703 = charset_list = Vemacs_mule_charset_list; |
fc9cda144ffc
(encode_coding_emacs_mule): Resync charset_list to
Kenichi Handa <handa@m17n.org>
parents:
89642
diff
changeset
|
2704 } |
88365 | 2705 |
2706 while (charbuf < charbuf_end) | |
2707 { | |
2708 ASSURE_DESTINATION (safe_room); | |
2709 c = *charbuf++; | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2710 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2711 if (c < 0) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2712 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2713 /* Handle an annotation. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2714 switch (*charbuf) |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2715 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2716 case CODING_ANNOTATE_COMPOSITION_MASK: |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2717 /* Not yet implemented. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2718 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2719 case CODING_ANNOTATE_CHARSET_MASK: |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2720 preferred_charset_id = charbuf[3]; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2721 if (preferred_charset_id >= 0 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2722 && NILP (Fmemq (make_number (preferred_charset_id), |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2723 charset_list))) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2724 preferred_charset_id = -1; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2725 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2726 default: |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2727 abort (); |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2728 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2729 charbuf += -c - 1; |
32806
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2730 continue; |
9502d0a5b2ad
(decode_coding_emacs_mule): If coding->eol_type is CR
Eli Zaretskii <eliz@gnu.org>
parents:
32745
diff
changeset
|
2731 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2732 |
88365 | 2733 if (ASCII_CHAR_P (c)) |
2734 EMIT_ONE_ASCII_BYTE (c); | |
88690
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
2735 else if (CHAR_BYTE8_P (c)) |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
2736 { |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
2737 c = CHAR_TO_BYTE8 (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
2738 EMIT_ONE_BYTE (c); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2739 } |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2740 else |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2741 { |
88365 | 2742 struct charset *charset; |
2743 unsigned code; | |
2744 int dimension; | |
2745 int emacs_mule_id; | |
2746 unsigned char leading_codes[2]; | |
2747 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2748 if (preferred_charset_id >= 0) |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2749 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2750 charset = CHARSET_FROM_ID (preferred_charset_id); |
100176
5706ca7c3d02
(encode_coding_emacs_mule): Be sure to set `code'.
Kenichi Handa <handa@m17n.org>
parents:
100170
diff
changeset
|
2751 if (CHAR_CHARSET_P (c, charset)) |
5706ca7c3d02
(encode_coding_emacs_mule): Be sure to set `code'.
Kenichi Handa <handa@m17n.org>
parents:
100170
diff
changeset
|
2752 code = ENCODE_CHAR (charset, c); |
5706ca7c3d02
(encode_coding_emacs_mule): Be sure to set `code'.
Kenichi Handa <handa@m17n.org>
parents:
100170
diff
changeset
|
2753 else |
5706ca7c3d02
(encode_coding_emacs_mule): Be sure to set `code'.
Kenichi Handa <handa@m17n.org>
parents:
100170
diff
changeset
|
2754 charset = char_charset (c, charset_list, &code); |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2755 } |
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2756 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
2757 charset = char_charset (c, charset_list, &code); |
88365 | 2758 if (! charset) |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2759 { |
88365 | 2760 c = coding->default_char; |
2761 if (ASCII_CHAR_P (c)) | |
2762 { | |
2763 EMIT_ONE_ASCII_BYTE (c); | |
2764 continue; | |
2765 } | |
2766 charset = char_charset (c, charset_list, &code); | |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2767 } |
88365 | 2768 dimension = CHARSET_DIMENSION (charset); |
2769 emacs_mule_id = CHARSET_EMACS_MULE_ID (charset); | |
2770 EMACS_MULE_LEADING_CODES (emacs_mule_id, leading_codes); | |
2771 EMIT_ONE_BYTE (leading_codes[0]); | |
2772 if (leading_codes[1]) | |
2773 EMIT_ONE_BYTE (leading_codes[1]); | |
2774 if (dimension == 1) | |
89642
e97441b6244b
(encode_coding_emacs_mule): Emit bytes with MSB.
Kenichi Handa <handa@m17n.org>
parents:
89575
diff
changeset
|
2775 EMIT_ONE_BYTE (code | 0x80); |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2776 else |
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2777 { |
89642
e97441b6244b
(encode_coding_emacs_mule): Emit bytes with MSB.
Kenichi Handa <handa@m17n.org>
parents:
89575
diff
changeset
|
2778 code |= 0x8080; |
88365 | 2779 EMIT_ONE_BYTE (code >> 8); |
2780 EMIT_ONE_BYTE (code & 0xFF); | |
54320
a7e59b39de35
(decode_coding_emacs_mule): Handle insufficent source correctly.
Kenichi Handa <handa@m17n.org>
parents:
54303
diff
changeset
|
2781 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2782 } |
88365 | 2783 } |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
2784 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 2785 coding->produced_char += produced_chars; |
2786 coding->produced = dst - coding->destination; | |
2787 return 0; | |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
2788 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2789 |
17052 | 2790 |
88365 | 2791 /*** 7. ISO2022 handlers ***/ |
17052 | 2792 |
2793 /* The following note describes the coding system ISO2022 briefly. | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2794 Since the intention of this note is to help understand the |
35053 | 2795 functions in this file, some parts are NOT ACCURATE or are OVERLY |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2796 SIMPLIFIED. For thorough understanding, please refer to the |
35053 | 2797 original document of ISO2022. This is equivalent to the standard |
2798 ECMA-35, obtainable from <URL:http://www.ecma.ch/> (*). | |
17052 | 2799 |
2800 ISO2022 provides many mechanisms to encode several character sets | |
35053 | 2801 in 7-bit and 8-bit environments. For 7-bit environments, all text |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2802 is encoded using bytes less than 128. This may make the encoded |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2803 text a little bit longer, but the text passes more easily through |
35053 | 2804 several types of gateway, some of which strip off the MSB (Most |
36087 | 2805 Significant Bit). |
35053 | 2806 |
2807 There are two kinds of character sets: control character sets and | |
2808 graphic character sets. The former contain control characters such | |
17052 | 2809 as `newline' and `escape' to provide control functions (control |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2810 functions are also provided by escape sequences). The latter |
35053 | 2811 contain graphic characters such as 'A' and '-'. Emacs recognizes |
17052 | 2812 two control character sets and many graphic character sets. |
2813 | |
2814 Graphic character sets are classified into one of the following | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2815 four classes, according to the number of bytes (DIMENSION) and |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2816 number of characters in one dimension (CHARS) of the set: |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2817 - DIMENSION1_CHARS94 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2818 - DIMENSION1_CHARS96 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2819 - DIMENSION2_CHARS94 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2820 - DIMENSION2_CHARS96 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2821 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2822 In addition, each character set is assigned an identification tag, |
35053 | 2823 unique for each set, called the "final character" (denoted as <F> |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2824 hereafter). The <F> of each character set is decided by ECMA(*) |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2825 when it is registered in ISO. The code range of <F> is 0x30..0x7F |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2826 (0x30..0x3F are for private use only). |
17052 | 2827 |
2828 Note (*): ECMA = European Computer Manufacturers Association | |
2829 | |
35053 | 2830 Here are examples of graphic character sets [NAME(<F>)]: |
17052 | 2831 o DIMENSION1_CHARS94 -- ASCII('B'), right-half-of-JISX0201('I'), ... |
2832 o DIMENSION1_CHARS96 -- right-half-of-ISO8859-1('A'), ... | |
2833 o DIMENSION2_CHARS94 -- GB2312('A'), JISX0208('B'), ... | |
2834 o DIMENSION2_CHARS96 -- none for the moment | |
2835 | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2836 A code area (1 byte=8 bits) is divided into 4 areas, C0, GL, C1, and GR. |
17052 | 2837 C0 [0x00..0x1F] -- control character plane 0 |
2838 GL [0x20..0x7F] -- graphic character plane 0 | |
2839 C1 [0x80..0x9F] -- control character plane 1 | |
2840 GR [0xA0..0xFF] -- graphic character plane 1 | |
2841 | |
2842 A control character set is directly designated and invoked to C0 or | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2843 C1 by an escape sequence. The most common case is that: |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2844 - ISO646's control character set is designated/invoked to C0, and |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2845 - ISO6429's control character set is designated/invoked to C1, |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2846 and usually these designations/invocations are omitted in encoded |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2847 text. In a 7-bit environment, only C0 can be used, and a control |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2848 character for C1 is encoded by an appropriate escape sequence to |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2849 fit into the environment. All control characters for C1 are |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2850 defined to have corresponding escape sequences. |
17052 | 2851 |
2852 A graphic character set is at first designated to one of four | |
2853 graphic registers (G0 through G3), then these graphic registers are | |
2854 invoked to GL or GR. These designations and invocations can be | |
2855 done independently. The most common case is that G0 is invoked to | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2856 GL, G1 is invoked to GR, and ASCII is designated to G0. Usually |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2857 these invocations and designations are omitted in encoded text. |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2858 In a 7-bit environment, only GL can be used. |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2859 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2860 When a graphic character set of CHARS94 is invoked to GL, codes |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2861 0x20 and 0x7F of the GL area work as control characters SPACE and |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2862 DEL respectively, and codes 0xA0 and 0xFF of the GR area should not |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2863 be used. |
17052 | 2864 |
2865 There are two ways of invocation: locking-shift and single-shift. | |
2866 With locking-shift, the invocation lasts until the next different | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2867 invocation, whereas with single-shift, the invocation affects the |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2868 following character only and doesn't affect the locking-shift |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2869 state. Invocations are done by the following control characters or |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2870 escape sequences: |
17052 | 2871 |
2872 ---------------------------------------------------------------------- | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2873 abbrev function cntrl escape seq description |
17052 | 2874 ---------------------------------------------------------------------- |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2875 SI/LS0 (shift-in) 0x0F none invoke G0 into GL |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2876 SO/LS1 (shift-out) 0x0E none invoke G1 into GL |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2877 LS2 (locking-shift-2) none ESC 'n' invoke G2 into GL |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2878 LS3 (locking-shift-3) none ESC 'o' invoke G3 into GL |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2879 LS1R (locking-shift-1 right) none ESC '~' invoke G1 into GR (*) |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2880 LS2R (locking-shift-2 right) none ESC '}' invoke G2 into GR (*) |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2881 LS3R (locking-shift 3 right) none ESC '|' invoke G3 into GR (*) |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2882 SS2 (single-shift-2) 0x8E ESC 'N' invoke G2 for one char |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2883 SS3 (single-shift-3) 0x8F ESC 'O' invoke G3 for one char |
17052 | 2884 ---------------------------------------------------------------------- |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2885 (*) These are not used by any known coding system. |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2886 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2887 Control characters for these functions are defined by macros |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2888 ISO_CODE_XXX in `coding.h'. |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2889 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2890 Designations are done by the following escape sequences: |
17052 | 2891 ---------------------------------------------------------------------- |
2892 escape sequence description | |
2893 ---------------------------------------------------------------------- | |
2894 ESC '(' <F> designate DIMENSION1_CHARS94<F> to G0 | |
2895 ESC ')' <F> designate DIMENSION1_CHARS94<F> to G1 | |
2896 ESC '*' <F> designate DIMENSION1_CHARS94<F> to G2 | |
2897 ESC '+' <F> designate DIMENSION1_CHARS94<F> to G3 | |
2898 ESC ',' <F> designate DIMENSION1_CHARS96<F> to G0 (*) | |
2899 ESC '-' <F> designate DIMENSION1_CHARS96<F> to G1 | |
2900 ESC '.' <F> designate DIMENSION1_CHARS96<F> to G2 | |
2901 ESC '/' <F> designate DIMENSION1_CHARS96<F> to G3 | |
2902 ESC '$' '(' <F> designate DIMENSION2_CHARS94<F> to G0 (**) | |
2903 ESC '$' ')' <F> designate DIMENSION2_CHARS94<F> to G1 | |
2904 ESC '$' '*' <F> designate DIMENSION2_CHARS94<F> to G2 | |
2905 ESC '$' '+' <F> designate DIMENSION2_CHARS94<F> to G3 | |
2906 ESC '$' ',' <F> designate DIMENSION2_CHARS96<F> to G0 (*) | |
2907 ESC '$' '-' <F> designate DIMENSION2_CHARS96<F> to G1 | |
2908 ESC '$' '.' <F> designate DIMENSION2_CHARS96<F> to G2 | |
2909 ESC '$' '/' <F> designate DIMENSION2_CHARS96<F> to G3 | |
2910 ---------------------------------------------------------------------- | |
2911 | |
2912 In this list, "DIMENSION1_CHARS94<F>" means a graphic character set | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2913 of dimension 1, chars 94, and final character <F>, etc... |
17052 | 2914 |
2915 Note (*): Although these designations are not allowed in ISO2022, | |
2916 Emacs accepts them on decoding, and produces them on encoding | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2917 CHARS96 character sets in a coding system which is characterized as |
17052 | 2918 7-bit environment, non-locking-shift, and non-single-shift. |
2919 | |
2920 Note (**): If <F> is '@', 'A', or 'B', the intermediate character | |
88365 | 2921 '(' must be omitted. We refer to this as "short-form" hereafter. |
17052 | 2922 |
35053 | 2923 Now you may notice that there are a lot of ways of encoding the |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2924 same multilingual text in ISO2022. Actually, there exist many |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2925 coding systems such as Compound Text (used in X11's inter client |
36087 | 2926 communication, ISO-2022-JP (used in Japanese Internet), ISO-2022-KR |
2927 (used in Korean Internet), EUC (Extended UNIX Code, used in Asian | |
17052 | 2928 localized platforms), and all of these are variants of ISO2022. |
2929 | |
2930 In addition to the above, Emacs handles two more kinds of escape | |
2931 sequences: ISO6429's direction specification and Emacs' private | |
2932 sequence for specifying character composition. | |
2933 | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2934 ISO6429's direction specification takes the following form: |
17052 | 2935 o CSI ']' -- end of the current direction |
2936 o CSI '0' ']' -- end of the current direction | |
2937 o CSI '1' ']' -- start of left-to-right text | |
2938 o CSI '2' ']' -- start of right-to-left text | |
2939 The control character CSI (0x9B: control sequence introducer) is | |
24425
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2940 abbreviated to the escape sequence ESC '[' in a 7-bit environment. |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2941 |
61c6b3be1d51
Comment for ISO 2022 encoding mechanism modified.
Kenichi Handa <handa@m17n.org>
parents:
24344
diff
changeset
|
2942 Character composition specification takes the following form: |
26847 | 2943 o ESC '0' -- start relative composition |
2944 o ESC '1' -- end composition | |
2945 o ESC '2' -- start rule-base composition (*) | |
2946 o ESC '3' -- start relative composition with alternate chars (**) | |
2947 o ESC '4' -- start rule-base composition with alternate chars (**) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2948 Since these are not standard escape sequences of any ISO standard, |
35053 | 2949 the use of them with these meanings is restricted to Emacs only. |
2950 | |
88771 | 2951 (*) This form is used only in Emacs 20.7 and older versions, |
2952 but newer versions can safely decode it. | |
35053 | 2953 (**) This form is used only in Emacs 21.1 and newer versions, |
88771 | 2954 and older versions can't decode it. |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2955 |
35053 | 2956 Here's a list of example usages of these composition escape |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2957 sequences (categorized by `enum composition_method'). |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2958 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2959 COMPOSITION_RELATIVE: |
26847 | 2960 ESC 0 CHAR [ CHAR ] ESC 1 |
36087 | 2961 COMPOSITION_WITH_RULE: |
26847 | 2962 ESC 2 CHAR [ RULE CHAR ] ESC 1 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2963 COMPOSITION_WITH_ALTCHARS: |
26847 | 2964 ESC 3 ALTCHAR [ ALTCHAR ] ESC 0 CHAR [ CHAR ] ESC 1 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
2965 COMPOSITION_WITH_RULE_ALTCHARS: |
26847 | 2966 ESC 4 ALTCHAR [ RULE ALTCHAR ] ESC 0 CHAR [ CHAR ] ESC 1 */ |
17052 | 2967 |
2968 enum iso_code_class_type iso_code_class[256]; | |
2969 | |
88365 | 2970 #define SAFE_CHARSET_P(coding, id) \ |
2971 ((id) <= (coding)->max_charset_id \ | |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
2972 && (coding)->safe_charsets[id] != 255) |
88365 | 2973 |
2974 | |
2975 #define SHIFT_OUT_OK(category) \ | |
2976 (CODING_ISO_INITIAL (&coding_categories[category], 1) >= 0) | |
2977 | |
2978 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
2979 setup_iso_safe_charsets (Lisp_Object attrs) |
88365 | 2980 { |
2981 Lisp_Object charset_list, safe_charsets; | |
2982 Lisp_Object request; | |
2983 Lisp_Object reg_usage; | |
2984 Lisp_Object tail; | |
2985 int reg94, reg96; | |
2986 int flags = XINT (AREF (attrs, coding_attr_iso_flags)); | |
2987 int max_charset_id; | |
2988 | |
2989 charset_list = CODING_ATTR_CHARSET_LIST (attrs); | |
2990 if ((flags & CODING_ISO_FLAG_FULL_SUPPORT) | |
2991 && ! EQ (charset_list, Viso_2022_charset_list)) | |
2992 { | |
2993 CODING_ATTR_CHARSET_LIST (attrs) | |
2994 = charset_list = Viso_2022_charset_list; | |
2995 ASET (attrs, coding_attr_safe_charsets, Qnil); | |
2996 } | |
2997 | |
2998 if (STRINGP (AREF (attrs, coding_attr_safe_charsets))) | |
2999 return; | |
3000 | |
3001 max_charset_id = 0; | |
3002 for (tail = charset_list; CONSP (tail); tail = XCDR (tail)) | |
3003 { | |
3004 int id = XINT (XCAR (tail)); | |
3005 if (max_charset_id < id) | |
3006 max_charset_id = id; | |
3007 } | |
3008 | |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
3009 safe_charsets = make_uninit_string (max_charset_id + 1); |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
3010 memset (SDATA (safe_charsets), 255, max_charset_id + 1); |
88365 | 3011 request = AREF (attrs, coding_attr_iso_request); |
3012 reg_usage = AREF (attrs, coding_attr_iso_usage); | |
3013 reg94 = XINT (XCAR (reg_usage)); | |
3014 reg96 = XINT (XCDR (reg_usage)); | |
3015 | |
3016 for (tail = charset_list; CONSP (tail); tail = XCDR (tail)) | |
3017 { | |
3018 Lisp_Object id; | |
3019 Lisp_Object reg; | |
3020 struct charset *charset; | |
3021 | |
3022 id = XCAR (tail); | |
3023 charset = CHARSET_FROM_ID (XINT (id)); | |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3024 reg = Fcdr (Fassq (id, request)); |
88365 | 3025 if (! NILP (reg)) |
89483 | 3026 SSET (safe_charsets, XINT (id), XINT (reg)); |
88365 | 3027 else if (charset->iso_chars_96) |
3028 { | |
3029 if (reg96 < 4) | |
89483 | 3030 SSET (safe_charsets, XINT (id), reg96); |
88365 | 3031 } |
3032 else | |
3033 { | |
3034 if (reg94 < 4) | |
89483 | 3035 SSET (safe_charsets, XINT (id), reg94); |
88365 | 3036 } |
3037 } | |
3038 ASET (attrs, coding_attr_safe_charsets, safe_charsets); | |
3039 } | |
3040 | |
50047
8e17fbb2ac77
(CODING_ADD_COMPOSITION_COMPONENT): If the number of
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
3041 |
17052 | 3042 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". |
110983 | 3043 Check if a text is encoded in one of ISO-2022 based coding systems. |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3044 If it is, return 1, else return 0. */ |
17052 | 3045 |
34531
37f85e931855
(ONE_MORE_BYTE_CHECK_MULTIBYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34197
diff
changeset
|
3046 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
3047 detect_coding_iso_2022 (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
3048 struct coding_detection_info *detect_info) |
17052 | 3049 { |
89483 | 3050 const unsigned char *src = coding->source, *src_base = src; |
3051 const unsigned char *src_end = coding->source + coding->src_bytes; | |
88365 | 3052 int multibytep = coding->src_multibyte; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3053 int single_shifting = 0; |
88365 | 3054 int id; |
3055 int c, c1; | |
3056 int consumed_chars = 0; | |
3057 int i; | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3058 int rejected = 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3059 int found = 0; |
99753
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3060 int composition_count = -1; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3061 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3062 detect_info->checked |= CATEGORY_MASK_ISO; |
88365 | 3063 |
3064 for (i = coding_category_iso_7; i <= coding_category_iso_8_else; i++) | |
3065 { | |
3066 struct coding_system *this = &(coding_categories[i]); | |
3067 Lisp_Object attrs, val; | |
3068 | |
94944
c16046e21b90
(detect_coding_iso_2022): Ignore a coding category that
Kenichi Handa <handa@m17n.org>
parents:
93877
diff
changeset
|
3069 if (this->id < 0) |
c16046e21b90
(detect_coding_iso_2022): Ignore a coding category that
Kenichi Handa <handa@m17n.org>
parents:
93877
diff
changeset
|
3070 continue; |
88365 | 3071 attrs = CODING_ID_ATTRS (this->id); |
3072 if (CODING_ISO_FLAGS (this) & CODING_ISO_FLAG_FULL_SUPPORT | |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
3073 && ! EQ (CODING_ATTR_CHARSET_LIST (attrs), Viso_2022_charset_list)) |
88365 | 3074 setup_iso_safe_charsets (attrs); |
3075 val = CODING_ATTR_SAFE_CHARSETS (attrs); | |
89483 | 3076 this->max_charset_id = SCHARS (val) - 1; |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
3077 this->safe_charsets = SDATA (val); |
88365 | 3078 } |
3079 | |
3080 /* A coding system of this category is always ASCII compatible. */ | |
3081 src += coding->head_ascii; | |
3082 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3083 while (rejected != CATEGORY_MASK_ISO) |
88365 | 3084 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
3085 src_base = src; |
88365 | 3086 ONE_MORE_BYTE (c); |
17052 | 3087 switch (c) |
3088 { | |
3089 case ISO_CODE_ESC: | |
30204
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
3090 if (inhibit_iso_escape_detection) |
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
3091 break; |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3092 single_shifting = 0; |
88365 | 3093 ONE_MORE_BYTE (c); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3094 if (c >= '(' && c <= '/') |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3095 { |
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3096 /* Designation sequence for a charset of dimension 1. */ |
88365 | 3097 ONE_MORE_BYTE (c1); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3098 if (c1 < ' ' || c1 >= 0x80 |
88365 | 3099 || (id = iso_charset_table[0][c >= ','][c1]) < 0) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3100 /* Invalid designation sequence. Just ignore. */ |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3101 break; |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3102 } |
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3103 else if (c == '$') |
17052 | 3104 { |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3105 /* Designation sequence for a charset of dimension 2. */ |
88365 | 3106 ONE_MORE_BYTE (c); |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3107 if (c >= '@' && c <= 'B') |
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3108 /* Designation for JISX0208.1978, GB2312, or JISX0208. */ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3109 id = iso_charset_table[1][0][c]; |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3110 else if (c >= '(' && c <= '/') |
17320
9d15bec5f47e
(detect_coding_iso2022, detect_coding_mask): Ignore
Kenichi Handa <handa@m17n.org>
parents:
17304
diff
changeset
|
3111 { |
88365 | 3112 ONE_MORE_BYTE (c1); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3113 if (c1 < ' ' || c1 >= 0x80 |
88365 | 3114 || (id = iso_charset_table[1][c >= ','][c1]) < 0) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3115 /* Invalid designation sequence. Just ignore. */ |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3116 break; |
17320
9d15bec5f47e
(detect_coding_iso2022, detect_coding_mask): Ignore
Kenichi Handa <handa@m17n.org>
parents:
17304
diff
changeset
|
3117 } |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3118 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3119 /* Invalid designation sequence. Just ignore it. */ |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3120 break; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3121 } |
23116
6736da064f4a
(detect_coding_iso2022): Handle ESC N and ESC O
Kenichi Handa <handa@m17n.org>
parents:
23089
diff
changeset
|
3122 else if (c == 'N' || c == 'O') |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3123 { |
23116
6736da064f4a
(detect_coding_iso2022): Handle ESC N and ESC O
Kenichi Handa <handa@m17n.org>
parents:
23089
diff
changeset
|
3124 /* ESC <Fe> for SS2 or SS3. */ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3125 single_shifting = 1; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3126 rejected |= CATEGORY_MASK_ISO_7BIT | CATEGORY_MASK_ISO_8BIT; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3127 break; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3128 } |
99753
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3129 else if (c == '1') |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3130 { |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3131 /* End of composition. */ |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3132 if (composition_count < 0 |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3133 || composition_count > MAX_COMPOSITION_COMPONENTS) |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3134 /* Invalid */ |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3135 break; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3136 composition_count = -1; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3137 found |= CATEGORY_MASK_ISO; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3138 } |
26847 | 3139 else if (c >= '0' && c <= '4') |
3140 { | |
3141 /* ESC <Fp> for start/end composition. */ | |
99753
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3142 composition_count = 0; |
26847 | 3143 break; |
3144 } | |
19134
8fa6e23f8d22
(detect_coding_iso2022): Do not exclude posibility of
Kenichi Handa <handa@m17n.org>
parents:
19118
diff
changeset
|
3145 else |
88365 | 3146 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3147 /* Invalid escape sequence. Just ignore it. */ |
88365 | 3148 break; |
3149 } | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3150 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3151 /* We found a valid designation sequence for CHARSET. */ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3152 rejected |= CATEGORY_MASK_ISO_8BIT; |
88365 | 3153 if (SAFE_CHARSET_P (&coding_categories[coding_category_iso_7], |
3154 id)) | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3155 found |= CATEGORY_MASK_ISO_7; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3156 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3157 rejected |= CATEGORY_MASK_ISO_7; |
88365 | 3158 if (SAFE_CHARSET_P (&coding_categories[coding_category_iso_7_tight], |
3159 id)) | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3160 found |= CATEGORY_MASK_ISO_7_TIGHT; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3161 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3162 rejected |= CATEGORY_MASK_ISO_7_TIGHT; |
88365 | 3163 if (SAFE_CHARSET_P (&coding_categories[coding_category_iso_7_else], |
3164 id)) | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3165 found |= CATEGORY_MASK_ISO_7_ELSE; |
23116
6736da064f4a
(detect_coding_iso2022): Handle ESC N and ESC O
Kenichi Handa <handa@m17n.org>
parents:
23089
diff
changeset
|
3166 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3167 rejected |= CATEGORY_MASK_ISO_7_ELSE; |
88365 | 3168 if (SAFE_CHARSET_P (&coding_categories[coding_category_iso_8_else], |
3169 id)) | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3170 found |= CATEGORY_MASK_ISO_8_ELSE; |
23116
6736da064f4a
(detect_coding_iso2022): Handle ESC N and ESC O
Kenichi Handa <handa@m17n.org>
parents:
23089
diff
changeset
|
3171 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3172 rejected |= CATEGORY_MASK_ISO_8_ELSE; |
17052 | 3173 break; |
3174 | |
3175 case ISO_CODE_SO: | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3176 case ISO_CODE_SI: |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3177 /* Locking shift out/in. */ |
30204
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
3178 if (inhibit_iso_escape_detection) |
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
3179 break; |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3180 single_shifting = 0; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3181 rejected |= CATEGORY_MASK_ISO_7BIT | CATEGORY_MASK_ISO_8BIT; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3182 break; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3183 |
17052 | 3184 case ISO_CODE_CSI: |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3185 /* Control sequence introducer. */ |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3186 single_shifting = 0; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3187 rejected |= CATEGORY_MASK_ISO_7BIT | CATEGORY_MASK_ISO_7_ELSE; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3188 found |= CATEGORY_MASK_ISO_8_ELSE; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3189 goto check_extra_latin; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3190 |
17052 | 3191 case ISO_CODE_SS2: |
3192 case ISO_CODE_SS3: | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3193 /* Single shift. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3194 if (inhibit_iso_escape_detection) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3195 break; |
89780
a53cb5864a40
(detect_coding_iso_2022): Fix handling of SS2 and SS3.
Kenichi Handa <handa@m17n.org>
parents:
89779
diff
changeset
|
3196 single_shifting = 0; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3197 rejected |= CATEGORY_MASK_ISO_7BIT; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3198 if (CODING_ISO_FLAGS (&coding_categories[coding_category_iso_8_1]) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3199 & CODING_ISO_FLAG_SINGLE_SHIFT) |
89780
a53cb5864a40
(detect_coding_iso_2022): Fix handling of SS2 and SS3.
Kenichi Handa <handa@m17n.org>
parents:
89779
diff
changeset
|
3200 found |= CATEGORY_MASK_ISO_8_1, single_shifting = 1; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3201 if (CODING_ISO_FLAGS (&coding_categories[coding_category_iso_8_2]) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3202 & CODING_ISO_FLAG_SINGLE_SHIFT) |
89780
a53cb5864a40
(detect_coding_iso_2022): Fix handling of SS2 and SS3.
Kenichi Handa <handa@m17n.org>
parents:
89779
diff
changeset
|
3203 found |= CATEGORY_MASK_ISO_8_2, single_shifting = 1; |
a53cb5864a40
(detect_coding_iso_2022): Fix handling of SS2 and SS3.
Kenichi Handa <handa@m17n.org>
parents:
89779
diff
changeset
|
3204 if (single_shifting) |
a53cb5864a40
(detect_coding_iso_2022): Fix handling of SS2 and SS3.
Kenichi Handa <handa@m17n.org>
parents:
89779
diff
changeset
|
3205 break; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3206 goto check_extra_latin; |
17052 | 3207 |
3208 default: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
3209 if (c < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
3210 continue; |
17052 | 3211 if (c < 0x80) |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3212 { |
99753
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3213 if (composition_count >= 0) |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3214 composition_count++; |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3215 single_shifting = 0; |
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3216 break; |
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3217 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3218 if (c >= 0xA0) |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
3219 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3220 rejected |= CATEGORY_MASK_ISO_7BIT | CATEGORY_MASK_ISO_7_ELSE; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3221 found |= CATEGORY_MASK_ISO_8_1; |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3222 /* Check the length of succeeding codes of the range |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3223 0xA0..0FF. If the byte length is even, we include |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3224 CATEGORY_MASK_ISO_8_2 in `found'. We can check this |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3225 only when we are not single shifting. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3226 if (! single_shifting |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3227 && ! (rejected & CATEGORY_MASK_ISO_8_2)) |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3228 { |
29299
b33b38d81020
(detect_coding_iso2022): Fix code for checking
Kenichi Handa <handa@m17n.org>
parents:
29275
diff
changeset
|
3229 int i = 1; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3230 while (src < src_end) |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3231 { |
106826
64cd76243389
Fix handling of euc-xx coding systems.
Kenichi Handa <handa@m17n.org>
parents:
106815
diff
changeset
|
3232 src_base = src; |
88365 | 3233 ONE_MORE_BYTE (c); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3234 if (c < 0xA0) |
106826
64cd76243389
Fix handling of euc-xx coding systems.
Kenichi Handa <handa@m17n.org>
parents:
106815
diff
changeset
|
3235 { |
64cd76243389
Fix handling of euc-xx coding systems.
Kenichi Handa <handa@m17n.org>
parents:
106815
diff
changeset
|
3236 src = src_base; |
64cd76243389
Fix handling of euc-xx coding systems.
Kenichi Handa <handa@m17n.org>
parents:
106815
diff
changeset
|
3237 break; |
64cd76243389
Fix handling of euc-xx coding systems.
Kenichi Handa <handa@m17n.org>
parents:
106815
diff
changeset
|
3238 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3239 i++; |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3240 } |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3241 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3242 if (i & 1 && src < src_end) |
99753
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3243 { |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3244 rejected |= CATEGORY_MASK_ISO_8_2; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3245 if (composition_count >= 0) |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3246 composition_count += i; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3247 } |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3248 else |
99753
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3249 { |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3250 found |= CATEGORY_MASK_ISO_8_2; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3251 if (composition_count >= 0) |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3252 composition_count += i / 2; |
c457d1e5edff
(detect_coding_iso_2022): Reject invalid composition
Kenichi Handa <handa@m17n.org>
parents:
99074
diff
changeset
|
3253 } |
23088
45c36d636f66
(detect_coding_iso2022): Don't check the byte length of
Kenichi Handa <handa@m17n.org>
parents:
23082
diff
changeset
|
3254 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3255 break; |
17052 | 3256 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3257 check_extra_latin: |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3258 single_shifting = 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3259 if (! VECTORP (Vlatin_extra_code_table) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3260 || NILP (XVECTOR (Vlatin_extra_code_table)->contents[c])) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3261 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3262 rejected = CATEGORY_MASK_ISO; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3263 break; |
17052 | 3264 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3265 if (CODING_ISO_FLAGS (&coding_categories[coding_category_iso_8_1]) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3266 & CODING_ISO_FLAG_LATIN_EXTRA) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3267 found |= CATEGORY_MASK_ISO_8_1; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3268 else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3269 rejected |= CATEGORY_MASK_ISO_8_1; |
89780
a53cb5864a40
(detect_coding_iso_2022): Fix handling of SS2 and SS3.
Kenichi Handa <handa@m17n.org>
parents:
89779
diff
changeset
|
3270 rejected |= CATEGORY_MASK_ISO_8_2; |
17052 | 3271 } |
3272 } | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3273 detect_info->rejected |= CATEGORY_MASK_ISO; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3274 return 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3275 |
88365 | 3276 no_more_source: |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3277 detect_info->rejected |= rejected; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3278 detect_info->found |= (found & ~rejected); |
88365 | 3279 return 1; |
17052 | 3280 } |
3281 | |
3282 | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3283 /* Set designation state into CODING. Set CHARS_96 to -1 if the |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3284 escape sequence should be kept. */ |
88365 | 3285 #define DECODE_DESIGNATION(reg, dim, chars_96, final) \ |
3286 do { \ | |
3287 int id, prev; \ | |
3288 \ | |
3289 if (final < '0' || final >= 128 \ | |
3290 || ((id = ISO_CHARSET_TABLE (dim, chars_96, final)) < 0) \ | |
3291 || !SAFE_CHARSET_P (coding, id)) \ | |
3292 { \ | |
3293 CODING_ISO_DESIGNATION (coding, reg) = -2; \ | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3294 chars_96 = -1; \ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3295 break; \ |
88365 | 3296 } \ |
3297 prev = CODING_ISO_DESIGNATION (coding, reg); \ | |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3298 if (id == charset_jisx0201_roman) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3299 { \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3300 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_USE_ROMAN) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3301 id = charset_ascii; \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3302 } \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3303 else if (id == charset_jisx0208_1978) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3304 { \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3305 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_USE_OLDJIS) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3306 id = charset_jisx0208; \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
3307 } \ |
88365 | 3308 CODING_ISO_DESIGNATION (coding, reg) = id; \ |
3309 /* If there was an invalid designation to REG previously, and this \ | |
3310 designation is ASCII to REG, we should keep this designation \ | |
3311 sequence. */ \ | |
3312 if (prev == -2 && id == charset_ascii) \ | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3313 chars_96 = -1; \ |
17052 | 3314 } while (0) |
3315 | |
88365 | 3316 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3317 /* Handle these composition sequence (ALT: alternate char): |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3318 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3319 (1) relative composition: ESC 0 CHAR ... ESC 1 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3320 (2) rulebase composition: ESC 2 CHAR RULE CHAR RULE ... CHAR ESC 1 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3321 (3) altchar composition: ESC 3 ALT ... ALT ESC 0 CHAR ... ESC 1 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3322 (4) alt&rule composition: ESC 4 ALT RULE ... ALT ESC 0 CHAR ... ESC 1 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3323 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3324 When the start sequence (ESC 0/2/3/4) is found, this annotation |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3325 header is produced. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3326 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3327 [ -LENGTH(==-5) CODING_ANNOTATE_COMPOSITION_MASK NCHARS(==0) 0 METHOD ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3328 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3329 Then, upon reading CHAR or RULE (one or two bytes), these codes are |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3330 produced until the end sequence (ESC 1) is found: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3331 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3332 (1) CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3333 (2) CHAR -2 DECODED-RULE CHAR -2 DECODED-RULE ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3334 (3) ALT ... ALT -1 -1 CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3335 (4) ALT -2 DECODED-RULE ALT -2 DECODED-RULE ... ALT -1 -1 CHAR ... CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3336 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3337 When the end sequence (ESC 1) is found, LENGTH and NCHARS in the |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3338 annotation header is updated as below: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3339 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3340 (1) LENGTH: unchanged, NCHARS: number of CHARs |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3341 (2) LENGTH: unchanged, NCHARS: number of CHARs |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3342 (3) LENGTH: += number of ALTs + 2, NCHARS: number of CHARs |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3343 (4) LENGTH: += number of ALTs * 3, NCHARS: number of CHARs |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3344 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3345 If an error is found while composing, the annotation header is |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3346 changed to: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3347 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3348 [ ESC '0'/'2'/'3'/'4' -2 0 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3349 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3350 and the sequence [ -2 DECODED-RULE ] is changed to the original |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3351 byte sequence as below: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3352 o the original byte sequence is B: [ B -1 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3353 o the original byte sequence is B1 B2: [ B1 B2 ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3354 and the sequence [ -1 -1 ] is changed to the original byte |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3355 sequence: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3356 [ ESC '0' ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3357 */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3358 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3359 /* Decode a composition rule C1 and maybe one more byte from the |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3360 source, and set RULE to the encoded composition rule, NBYTES to the |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3361 length of the composition rule. If the rule is invalid, set RULE |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3362 to some negative value. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3363 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3364 #define DECODE_COMPOSITION_RULE(rule, nbytes) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3365 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3366 rule = c1 - 32; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3367 if (rule < 0) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3368 break; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3369 if (rule < 81) /* old format (before ver.21) */ \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3370 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3371 int gref = (rule) / 9; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3372 int nref = (rule) % 9; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3373 if (gref == 4) gref = 10; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3374 if (nref == 4) nref = 10; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3375 rule = COMPOSITION_ENCODE_RULE (gref, nref); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3376 nbytes = 1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3377 } \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3378 else /* new format (after ver.21) */ \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3379 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3380 int c; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3381 \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3382 ONE_MORE_BYTE (c); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3383 rule = COMPOSITION_ENCODE_RULE (rule - 81, c - 32); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3384 if (rule >= 0) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3385 rule += 0x100; /* to destinguish it from the old format */ \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3386 nbytes = 2; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3387 } \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3388 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3389 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3390 #define ENCODE_COMPOSITION_RULE(rule) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3391 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3392 int gref = (rule % 0x100) / 12, nref = (rule % 0x100) % 12; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3393 \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3394 if (rule < 0x100) /* old format */ \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3395 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3396 if (gref == 10) gref = 4; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3397 if (nref == 10) nref = 4; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3398 charbuf[idx] = 32 + gref * 9 + nref; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3399 charbuf[idx + 1] = -1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3400 new_chars++; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3401 } \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3402 else /* new format */ \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3403 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3404 charbuf[idx] = 32 + 81 + gref; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3405 charbuf[idx + 1] = 32 + nref; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3406 new_chars += 2; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3407 } \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3408 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3409 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3410 /* Finish the current composition as invalid. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3411 |
109100
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
107984
diff
changeset
|
3412 static int finish_composition (int *, struct composition_status *); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3413 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3414 static int |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
3415 finish_composition (int *charbuf, struct composition_status *cmp_status) |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3416 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3417 int idx = - cmp_status->length; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3418 int new_chars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3419 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3420 /* Recover the original ESC sequence */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3421 charbuf[idx++] = ISO_CODE_ESC; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3422 charbuf[idx++] = (cmp_status->method == COMPOSITION_RELATIVE ? '0' |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3423 : cmp_status->method == COMPOSITION_WITH_RULE ? '2' |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3424 : cmp_status->method == COMPOSITION_WITH_ALTCHARS ? '3' |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3425 /* cmp_status->method == COMPOSITION_WITH_RULE_ALTCHARS */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3426 : '4'); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3427 charbuf[idx++] = -2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3428 charbuf[idx++] = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3429 charbuf[idx++] = -1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3430 new_chars = cmp_status->nchars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3431 if (cmp_status->method >= COMPOSITION_WITH_RULE) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3432 for (; idx < 0; idx++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3433 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3434 int elt = charbuf[idx]; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3435 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3436 if (elt == -2) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3437 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3438 ENCODE_COMPOSITION_RULE (charbuf[idx + 1]); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3439 idx++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3440 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3441 else if (elt == -1) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3442 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3443 charbuf[idx++] = ISO_CODE_ESC; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3444 charbuf[idx] = '0'; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3445 new_chars += 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3446 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3447 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3448 cmp_status->state = COMPOSING_NO; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3449 return new_chars; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3450 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3451 |
110983 | 3452 /* If characters are under composition, finish the composition. */ |
88365 | 3453 #define MAYBE_FINISH_COMPOSITION() \ |
3454 do { \ | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3455 if (cmp_status->state != COMPOSING_NO) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3456 char_offset += finish_composition (charbuf, cmp_status); \ |
88365 | 3457 } while (0) |
3458 | |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
3459 /* Handle composition start sequence ESC 0, ESC 2, ESC 3, or ESC 4. |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3460 |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
3461 ESC 0 : relative composition : ESC 0 CHAR ... ESC 1 |
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
3462 ESC 2 : rulebase composition : ESC 2 CHAR RULE CHAR RULE ... CHAR ESC 1 |
88365 | 3463 ESC 3 : altchar composition : ESC 3 CHAR ... ESC 0 CHAR ... ESC 1 |
3464 ESC 4 : alt&rule composition : ESC 4 CHAR RULE ... CHAR ESC 0 CHAR ... ESC 1 | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3465 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3466 Produce this annotation sequence now: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3467 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3468 [ -LENGTH(==-4) CODING_ANNOTATE_COMPOSITION_MASK NCHARS(==0) METHOD ] |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3469 */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3470 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3471 #define DECODE_COMPOSITION_START(c1) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3472 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3473 if (c1 == '0' \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3474 && ((cmp_status->state == COMPOSING_COMPONENT_CHAR \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3475 && cmp_status->method == COMPOSITION_WITH_ALTCHARS) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3476 || (cmp_status->state == COMPOSING_COMPONENT_RULE \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3477 && cmp_status->method == COMPOSITION_WITH_RULE_ALTCHARS))) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3478 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3479 *charbuf++ = -1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3480 *charbuf++= -1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3481 cmp_status->state = COMPOSING_CHAR; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3482 cmp_status->length += 2; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3483 } \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3484 else \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3485 { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3486 MAYBE_FINISH_COMPOSITION (); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3487 cmp_status->method = (c1 == '0' ? COMPOSITION_RELATIVE \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3488 : c1 == '2' ? COMPOSITION_WITH_RULE \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3489 : c1 == '3' ? COMPOSITION_WITH_ALTCHARS \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3490 : COMPOSITION_WITH_RULE_ALTCHARS); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3491 cmp_status->state \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3492 = (c1 <= '2' ? COMPOSING_CHAR : COMPOSING_COMPONENT_CHAR); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3493 ADD_COMPOSITION_DATA (charbuf, 0, 0, cmp_status->method); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3494 cmp_status->length = MAX_ANNOTATION_LENGTH; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3495 cmp_status->nchars = cmp_status->ncomps = 0; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3496 coding->annotated = 1; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3497 } \ |
26847 | 3498 } while (0) |
3499 | |
88365 | 3500 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3501 /* Handle composition end sequence ESC 1. */ |
88365 | 3502 |
3503 #define DECODE_COMPOSITION_END() \ | |
3504 do { \ | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3505 if (cmp_status->nchars == 0 \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3506 || ((cmp_status->state == COMPOSING_CHAR) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3507 == (cmp_status->method == COMPOSITION_WITH_RULE))) \ |
88365 | 3508 { \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3509 MAYBE_FINISH_COMPOSITION (); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3510 goto invalid_code; \ |
88365 | 3511 } \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3512 if (cmp_status->method == COMPOSITION_WITH_ALTCHARS) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3513 charbuf[- cmp_status->length] -= cmp_status->ncomps + 2; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3514 else if (cmp_status->method == COMPOSITION_WITH_RULE_ALTCHARS) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3515 charbuf[- cmp_status->length] -= cmp_status->ncomps * 3; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3516 charbuf[- cmp_status->length + 2] = cmp_status->nchars; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3517 char_offset += cmp_status->nchars; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3518 cmp_status->state = COMPOSING_NO; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3519 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3520 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3521 /* Store a composition rule RULE in charbuf, and update cmp_status. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3522 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3523 #define STORE_COMPOSITION_RULE(rule) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3524 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3525 *charbuf++ = -2; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3526 *charbuf++ = rule; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3527 cmp_status->length += 2; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3528 cmp_status->state--; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3529 } while (0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3530 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3531 /* Store a composed char or a component char C in charbuf, and update |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3532 cmp_status. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3533 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3534 #define STORE_COMPOSITION_CHAR(c) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3535 do { \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3536 *charbuf++ = (c); \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3537 cmp_status->length++; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3538 if (cmp_status->state == COMPOSING_CHAR) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3539 cmp_status->nchars++; \ |
88365 | 3540 else \ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3541 cmp_status->ncomps++; \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3542 if (cmp_status->method == COMPOSITION_WITH_RULE \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3543 || (cmp_status->method == COMPOSITION_WITH_RULE_ALTCHARS \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3544 && cmp_status->state == COMPOSING_COMPONENT_CHAR)) \ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3545 cmp_status->state++; \ |
26847 | 3546 } while (0) |
3547 | |
3548 | |
17052 | 3549 /* See the above "GENERAL NOTES on `decode_coding_XXX ()' functions". */ |
3550 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3551 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
3552 decode_coding_iso_2022 (struct coding_system *coding) |
17052 | 3553 { |
89483 | 3554 const unsigned char *src = coding->source + coding->consumed; |
3555 const unsigned char *src_end = coding->source + coding->src_bytes; | |
3556 const unsigned char *src_base; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
3557 int *charbuf = coding->charbuf + coding->charbuf_used; |
110983 | 3558 /* We may produce two annotations (charset and composition) in one |
3559 loop and one more charset annotation at the end. */ | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3560 int *charbuf_end |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
3561 = coding->charbuf + coding->charbuf_size - (MAX_ANNOTATION_LENGTH * 3); |
88365 | 3562 int consumed_chars = 0, consumed_chars_base; |
3563 int multibytep = coding->src_multibyte; | |
17052 | 3564 /* Charsets invoked to graphic plane 0 and 1 respectively. */ |
88365 | 3565 int charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); |
3566 int charset_id_1 = CODING_ISO_INVOKED_CHARSET (coding, 1); | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3567 int charset_id_2, charset_id_3; |
88365 | 3568 struct charset *charset; |
3569 int c; | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3570 struct composition_status *cmp_status = CODING_ISO_CMP_STATUS (coding); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
3571 Lisp_Object attrs, charset_list; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3572 int char_offset = coding->produced_char; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3573 int last_offset = char_offset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3574 int last_id = charset_ascii; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
3575 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
3576 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3577 int byte_after_cr = -1; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3578 int i; |
88365 | 3579 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
3580 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 3581 setup_iso_safe_charsets (attrs); |
90772
b15334b4a9c3
(coding_alloc_by_making_gap): New arg offset.
Kenichi Handa <handa@m17n.org>
parents:
90737
diff
changeset
|
3582 /* Charset list may have been changed. */ |
b15334b4a9c3
(coding_alloc_by_making_gap): New arg offset.
Kenichi Handa <handa@m17n.org>
parents:
90737
diff
changeset
|
3583 charset_list = CODING_ATTR_CHARSET_LIST (attrs); |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
3584 coding->safe_charsets = SDATA (CODING_ATTR_SAFE_CHARSETS (attrs)); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3585 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3586 if (cmp_status->state != COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3587 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3588 for (i = 0; i < cmp_status->length; i++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3589 *charbuf++ = cmp_status->carryover[i]; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3590 coding->annotated = 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3591 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3592 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3593 while (1) |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3594 { |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3595 int c1, c2, c3; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3596 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3597 src_base = src; |
88365 | 3598 consumed_chars_base = consumed_chars; |
3599 | |
3600 if (charbuf >= charbuf_end) | |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
3601 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
3602 if (byte_after_cr >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
3603 src_base--; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
3604 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
3605 } |
88365 | 3606 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3607 if (byte_after_cr >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3608 c1 = byte_after_cr, byte_after_cr = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3609 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3610 ONE_MORE_BYTE (c1); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
3611 if (c1 < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
3612 goto invalid_code; |
17052 | 3613 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3614 if (CODING_ISO_EXTSEGMENT_LEN (coding) > 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3615 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3616 *charbuf++ = ASCII_BYTE_P (c1) ? c1 : BYTE8_TO_CHAR (c1); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3617 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3618 CODING_ISO_EXTSEGMENT_LEN (coding)--; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3619 continue; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3620 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3621 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3622 if (CODING_ISO_EMBEDDED_UTF_8 (coding)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3623 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3624 if (c1 == ISO_CODE_ESC) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3625 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3626 if (src + 1 >= src_end) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3627 goto no_more_source; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3628 *charbuf++ = ISO_CODE_ESC; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3629 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3630 if (src[0] == '%' && src[1] == '@') |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3631 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3632 src += 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3633 consumed_chars += 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3634 char_offset += 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3635 /* We are sure charbuf can contain two more chars. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3636 *charbuf++ = '%'; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3637 *charbuf++ = '@'; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3638 CODING_ISO_EMBEDDED_UTF_8 (coding) = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3639 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3640 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3641 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3642 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3643 *charbuf++ = ASCII_BYTE_P (c1) ? c1 : BYTE8_TO_CHAR (c1); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3644 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3645 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3646 continue; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3647 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3648 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3649 if ((cmp_status->state == COMPOSING_RULE |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3650 || cmp_status->state == COMPOSING_COMPONENT_RULE) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3651 && c1 != ISO_CODE_ESC) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3652 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3653 int rule, nbytes; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3654 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3655 DECODE_COMPOSITION_RULE (rule, nbytes); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3656 if (rule < 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3657 goto invalid_code; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3658 STORE_COMPOSITION_RULE (rule); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3659 continue; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3660 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3661 |
89279
1fd77c471ee6
(decode_coding_utf_8): When eol_type is Qdos, handle
Kenichi Handa <handa@m17n.org>
parents:
89227
diff
changeset
|
3662 /* We produce at most one character. */ |
17052 | 3663 switch (iso_code_class [c1]) |
3664 { | |
3665 case ISO_0x20_or_0x7F: | |
88365 | 3666 if (charset_id_0 < 0 |
3667 || ! CHARSET_ISO_CHARS_96 (CHARSET_FROM_ID (charset_id_0))) | |
88585
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
3668 /* This is SPACE or DEL. */ |
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
3669 charset = CHARSET_FROM_ID (charset_ascii); |
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
3670 else |
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
3671 charset = CHARSET_FROM_ID (charset_id_0); |
c7772f702227
(ONE_MORE_BYTE_NO_CHECK): Increment consumed_chars.
Kenichi Handa <handa@m17n.org>
parents:
88573
diff
changeset
|
3672 break; |
17052 | 3673 |
3674 case ISO_graphic_plane_0: | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3675 if (charset_id_0 < 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3676 charset = CHARSET_FROM_ID (charset_ascii); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3677 else |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3678 charset = CHARSET_FROM_ID (charset_id_0); |
17052 | 3679 break; |
3680 | |
3681 case ISO_0xA0_or_0xFF: | |
88365 | 3682 if (charset_id_1 < 0 |
3683 || ! CHARSET_ISO_CHARS_96 (CHARSET_FROM_ID (charset_id_1)) | |
3684 || CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS) | |
3685 goto invalid_code; | |
17052 | 3686 /* This is a graphic character, we fall down ... */ |
3687 | |
3688 case ISO_graphic_plane_1: | |
88365 | 3689 if (charset_id_1 < 0) |
3690 goto invalid_code; | |
3691 charset = CHARSET_FROM_ID (charset_id_1); | |
17052 | 3692 break; |
3693 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3694 case ISO_control_0: |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3695 if (eol_crlf && c1 == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
3696 ONE_MORE_BYTE (byte_after_cr); |
88365 | 3697 MAYBE_FINISH_COMPOSITION (); |
3698 charset = CHARSET_FROM_ID (charset_ascii); | |
17052 | 3699 break; |
3700 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3701 case ISO_control_1: |
88365 | 3702 goto invalid_code; |
17052 | 3703 |
3704 case ISO_shift_out: | |
88365 | 3705 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_LOCKING_SHIFT) |
3706 || CODING_ISO_DESIGNATION (coding, 1) < 0) | |
3707 goto invalid_code; | |
3708 CODING_ISO_INVOCATION (coding, 0) = 1; | |
3709 charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3710 continue; |
17052 | 3711 |
3712 case ISO_shift_in: | |
88365 | 3713 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_LOCKING_SHIFT)) |
3714 goto invalid_code; | |
3715 CODING_ISO_INVOCATION (coding, 0) = 0; | |
3716 charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3717 continue; |
17052 | 3718 |
3719 case ISO_single_shift_2_7: | |
106564
fea46c7aca79
(decode_coding_iso_2022): Ignore ISO_CODE_SS2_7 (0x19)
Kenichi Handa <handa@m17n.org>
parents:
105959
diff
changeset
|
3720 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS)) |
fea46c7aca79
(decode_coding_iso_2022): Ignore ISO_CODE_SS2_7 (0x19)
Kenichi Handa <handa@m17n.org>
parents:
105959
diff
changeset
|
3721 goto invalid_code; |
17052 | 3722 case ISO_single_shift_2: |
88365 | 3723 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT)) |
3724 goto invalid_code; | |
17052 | 3725 /* SS2 is handled as an escape sequence of ESC 'N' */ |
3726 c1 = 'N'; | |
3727 goto label_escape_sequence; | |
3728 | |
3729 case ISO_single_shift_3: | |
88365 | 3730 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT)) |
3731 goto invalid_code; | |
17052 | 3732 /* SS2 is handled as an escape sequence of ESC 'O' */ |
3733 c1 = 'O'; | |
3734 goto label_escape_sequence; | |
3735 | |
3736 case ISO_control_sequence_introducer: | |
3737 /* CSI is handled as an escape sequence of ESC '[' ... */ | |
3738 c1 = '['; | |
3739 goto label_escape_sequence; | |
3740 | |
3741 case ISO_escape: | |
3742 ONE_MORE_BYTE (c1); | |
3743 label_escape_sequence: | |
88365 | 3744 /* Escape sequences handled here are invocation, |
17052 | 3745 designation, direction specification, and character |
3746 composition specification. */ | |
3747 switch (c1) | |
3748 { | |
3749 case '&': /* revision of following character set */ | |
3750 ONE_MORE_BYTE (c1); | |
3751 if (!(c1 >= '@' && c1 <= '~')) | |
88365 | 3752 goto invalid_code; |
17052 | 3753 ONE_MORE_BYTE (c1); |
3754 if (c1 != ISO_CODE_ESC) | |
88365 | 3755 goto invalid_code; |
17052 | 3756 ONE_MORE_BYTE (c1); |
3757 goto label_escape_sequence; | |
3758 | |
3759 case '$': /* designation of 2-byte character set */ | |
88365 | 3760 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_DESIGNATION)) |
3761 goto invalid_code; | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3762 { |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3763 int reg, chars96; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3764 |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3765 ONE_MORE_BYTE (c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3766 if (c1 >= '@' && c1 <= 'B') |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3767 { /* designation of JISX0208.1978, GB2312.1980, |
23339
2da87b489590
(check_composing_code): Fix previous change. Now it
Kenichi Handa <handa@m17n.org>
parents:
23325
diff
changeset
|
3768 or JISX0208.1980 */ |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3769 reg = 0, chars96 = 0; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3770 } |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3771 else if (c1 >= 0x28 && c1 <= 0x2B) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3772 { /* designation of DIMENSION2_CHARS94 character set */ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3773 reg = c1 - 0x28, chars96 = 0; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3774 ONE_MORE_BYTE (c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3775 } |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3776 else if (c1 >= 0x2C && c1 <= 0x2F) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3777 { /* designation of DIMENSION2_CHARS96 character set */ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3778 reg = c1 - 0x2C, chars96 = 1; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3779 ONE_MORE_BYTE (c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3780 } |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3781 else |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3782 goto invalid_code; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3783 DECODE_DESIGNATION (reg, 2, chars96, c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3784 /* We must update these variables now. */ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3785 if (reg == 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3786 charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3787 else if (reg == 1) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3788 charset_id_1 = CODING_ISO_INVOKED_CHARSET (coding, 1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3789 if (chars96 < 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3790 goto invalid_code; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3791 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3792 continue; |
17052 | 3793 |
3794 case 'n': /* invocation of locking-shift-2 */ | |
88365 | 3795 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_LOCKING_SHIFT) |
3796 || CODING_ISO_DESIGNATION (coding, 2) < 0) | |
3797 goto invalid_code; | |
3798 CODING_ISO_INVOCATION (coding, 0) = 2; | |
3799 charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3800 continue; |
17052 | 3801 |
3802 case 'o': /* invocation of locking-shift-3 */ | |
88365 | 3803 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_LOCKING_SHIFT) |
3804 || CODING_ISO_DESIGNATION (coding, 3) < 0) | |
3805 goto invalid_code; | |
3806 CODING_ISO_INVOCATION (coding, 0) = 3; | |
3807 charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3808 continue; |
17052 | 3809 |
3810 case 'N': /* invocation of single-shift-2 */ | |
88365 | 3811 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT) |
3812 || CODING_ISO_DESIGNATION (coding, 2) < 0) | |
3813 goto invalid_code; | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3814 charset_id_2 = CODING_ISO_DESIGNATION (coding, 2); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3815 if (charset_id_2 < 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3816 charset = CHARSET_FROM_ID (charset_ascii); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3817 else |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3818 charset = CHARSET_FROM_ID (charset_id_2); |
17052 | 3819 ONE_MORE_BYTE (c1); |
30578
705b94e152b1
(decode_coding_iso2022): More strict check for handling single
Kenichi Handa <handa@m17n.org>
parents:
30487
diff
changeset
|
3820 if (c1 < 0x20 || (c1 >= 0x80 && c1 < 0xA0)) |
88365 | 3821 goto invalid_code; |
17052 | 3822 break; |
3823 | |
3824 case 'O': /* invocation of single-shift-3 */ | |
88365 | 3825 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT) |
3826 || CODING_ISO_DESIGNATION (coding, 3) < 0) | |
3827 goto invalid_code; | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3828 charset_id_3 = CODING_ISO_DESIGNATION (coding, 3); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3829 if (charset_id_3 < 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3830 charset = CHARSET_FROM_ID (charset_ascii); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3831 else |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3832 charset = CHARSET_FROM_ID (charset_id_3); |
17052 | 3833 ONE_MORE_BYTE (c1); |
30578
705b94e152b1
(decode_coding_iso2022): More strict check for handling single
Kenichi Handa <handa@m17n.org>
parents:
30487
diff
changeset
|
3834 if (c1 < 0x20 || (c1 >= 0x80 && c1 < 0xA0)) |
88365 | 3835 goto invalid_code; |
17052 | 3836 break; |
3837 | |
26847 | 3838 case '0': case '2': case '3': case '4': /* start composition */ |
88365 | 3839 if (! (coding->common_flags & CODING_ANNOTATE_COMPOSITION_MASK)) |
3840 goto invalid_code; | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3841 if (last_id != charset_ascii) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3842 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3843 ADD_CHARSET_DATA (charbuf, char_offset- last_offset, last_id); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3844 last_id = charset_ascii; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3845 last_offset = char_offset; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3846 } |
26847 | 3847 DECODE_COMPOSITION_START (c1); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3848 continue; |
17052 | 3849 |
26847 | 3850 case '1': /* end composition */ |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3851 if (cmp_status->state == COMPOSING_NO) |
88365 | 3852 goto invalid_code; |
3853 DECODE_COMPOSITION_END (); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3854 continue; |
17052 | 3855 |
3856 case '[': /* specification of direction */ | |
105179
8143cdf4806f
(decode_coding_iso_2022): Fix operator precedence.
Andreas Schwab <schwab@linux-m68k.org>
parents:
104636
diff
changeset
|
3857 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_DIRECTION)) |
88365 | 3858 goto invalid_code; |
17052 | 3859 /* For the moment, nested direction is not supported. |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3860 So, `coding->mode & CODING_MODE_DIRECTION' zero means |
110983 | 3861 left-to-right, and nonzero means right-to-left. */ |
17052 | 3862 ONE_MORE_BYTE (c1); |
3863 switch (c1) | |
3864 { | |
3865 case ']': /* end of the current direction */ | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3866 coding->mode &= ~CODING_MODE_DIRECTION; |
17052 | 3867 |
3868 case '0': /* end of the current direction */ | |
3869 case '1': /* start of left-to-right direction */ | |
3870 ONE_MORE_BYTE (c1); | |
3871 if (c1 == ']') | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3872 coding->mode &= ~CODING_MODE_DIRECTION; |
17052 | 3873 else |
88365 | 3874 goto invalid_code; |
17052 | 3875 break; |
3876 | |
3877 case '2': /* start of right-to-left direction */ | |
3878 ONE_MORE_BYTE (c1); | |
3879 if (c1 == ']') | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
3880 coding->mode |= CODING_MODE_DIRECTION; |
17052 | 3881 else |
88365 | 3882 goto invalid_code; |
17052 | 3883 break; |
3884 | |
3885 default: | |
88365 | 3886 goto invalid_code; |
17052 | 3887 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3888 continue; |
17052 | 3889 |
51311 | 3890 case '%': |
3891 ONE_MORE_BYTE (c1); | |
3892 if (c1 == '/') | |
3893 { | |
3894 /* CTEXT extended segment: | |
3895 ESC % / [0-4] M L --ENCODING-NAME-- \002 --BYTES-- | |
3896 We keep these bytes as is for the moment. | |
3897 They may be decoded by post-read-conversion. */ | |
3898 int dim, M, L; | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3899 int size; |
56191 | 3900 |
51311 | 3901 ONE_MORE_BYTE (dim); |
109710
62d9702eb261
Improve the encoding by compound-text-with-extensions.
Kenichi Handa <handa@etlken>
parents:
107507
diff
changeset
|
3902 if (dim < '0' || dim > '4') |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3903 goto invalid_code; |
51311 | 3904 ONE_MORE_BYTE (M); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3905 if (M < 128) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3906 goto invalid_code; |
51311 | 3907 ONE_MORE_BYTE (L); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3908 if (L < 128) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3909 goto invalid_code; |
51311 | 3910 size = ((M - 128) * 128) + (L - 128); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3911 if (charbuf + 6 > charbuf_end) |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3912 goto break_loop; |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3913 *charbuf++ = ISO_CODE_ESC; |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3914 *charbuf++ = '%'; |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3915 *charbuf++ = '/'; |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3916 *charbuf++ = dim; |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3917 *charbuf++ = BYTE8_TO_CHAR (M); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3918 *charbuf++ = BYTE8_TO_CHAR (L); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3919 CODING_ISO_EXTSEGMENT_LEN (coding) = size; |
51311 | 3920 } |
3921 else if (c1 == 'G') | |
3922 { | |
3923 /* XFree86 extension for embedding UTF-8 in CTEXT: | |
3924 ESC % G --UTF-8-BYTES-- ESC % @ | |
3925 We keep these bytes as is for the moment. | |
3926 They may be decoded by post-read-conversion. */ | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3927 if (charbuf + 3 > charbuf_end) |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3928 goto break_loop; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3929 *charbuf++ = ISO_CODE_ESC; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3930 *charbuf++ = '%'; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3931 *charbuf++ = 'G'; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3932 CODING_ISO_EMBEDDED_UTF_8 (coding) = 1; |
51311 | 3933 } |
3934 else | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3935 goto invalid_code; |
51311 | 3936 continue; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
3937 break; |
51311 | 3938 |
17052 | 3939 default: |
88365 | 3940 if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_DESIGNATION)) |
3941 goto invalid_code; | |
89873
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3942 { |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3943 int reg, chars96; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3944 |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3945 if (c1 >= 0x28 && c1 <= 0x2B) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3946 { /* designation of DIMENSION1_CHARS94 character set */ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3947 reg = c1 - 0x28, chars96 = 0; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3948 ONE_MORE_BYTE (c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3949 } |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3950 else if (c1 >= 0x2C && c1 <= 0x2F) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3951 { /* designation of DIMENSION1_CHARS96 character set */ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3952 reg = c1 - 0x2C, chars96 = 1; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3953 ONE_MORE_BYTE (c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3954 } |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3955 else |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3956 goto invalid_code; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3957 DECODE_DESIGNATION (reg, 1, chars96, c1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3958 /* We must update these variables now. */ |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3959 if (reg == 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3960 charset_id_0 = CODING_ISO_INVOKED_CHARSET (coding, 0); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3961 else if (reg == 1) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3962 charset_id_1 = CODING_ISO_INVOKED_CHARSET (coding, 1); |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3963 if (chars96 < 0) |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3964 goto invalid_code; |
9a279ff9d245
(DECODE_DESIGNATION): Set chars_96 to -1 instead of
Kenichi Handa <handa@m17n.org>
parents:
89863
diff
changeset
|
3965 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3966 continue; |
17052 | 3967 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3968 } |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3969 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3970 if (cmp_status->state == COMPOSING_NO |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
3971 && charset->id != charset_ascii |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3972 && last_id != charset->id) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3973 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3974 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
3975 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3976 last_id = charset->id; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3977 last_offset = char_offset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3978 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
3979 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3980 /* Now we know CHARSET and 1st position code C1 of a character. |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3981 Produce a decoded character while getting 2nd and 3rd |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3982 position codes C2, C3 if necessary. */ |
88365 | 3983 if (CHARSET_DIMENSION (charset) > 1) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3984 { |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3985 ONE_MORE_BYTE (c2); |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3986 if (c2 < 0x20 || (c2 >= 0x80 && c2 < 0xA0) |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3987 || ((c1 & 0x80) != (c2 & 0x80))) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
3988 /* C2 is not in a valid range. */ |
88365 | 3989 goto invalid_code; |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3990 if (CHARSET_DIMENSION (charset) == 2) |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3991 c1 = (c1 << 8) | c2; |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3992 else |
88365 | 3993 { |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3994 ONE_MORE_BYTE (c3); |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3995 if (c3 < 0x20 || (c3 >= 0x80 && c3 < 0xA0) |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3996 || ((c1 & 0x80) != (c3 & 0x80))) |
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3997 /* C3 is not in a valid range. */ |
88365 | 3998 goto invalid_code; |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
3999 c1 = (c1 << 16) | (c2 << 8) | c2; |
88365 | 4000 } |
17052 | 4001 } |
103474
7ead50363544
(decode_coding_iso_2022): Check MSB of bytes more rigidly.
Kenichi Handa <handa@m17n.org>
parents:
103448
diff
changeset
|
4002 c1 &= 0x7F7F7F; |
88365 | 4003 CODING_DECODE_CHAR (coding, src, src_base, src_end, charset, c1, c); |
4004 if (c < 0) | |
4005 { | |
4006 MAYBE_FINISH_COMPOSITION (); | |
4007 for (; src_base < src; src_base++, char_offset++) | |
4008 { | |
4009 if (ASCII_BYTE_P (*src_base)) | |
4010 *charbuf++ = *src_base; | |
4011 else | |
4012 *charbuf++ = BYTE8_TO_CHAR (*src_base); | |
4013 } | |
4014 } | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4015 else if (cmp_status->state == COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4016 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4017 *charbuf++ = c; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4018 char_offset++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4019 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4020 else if ((cmp_status->state == COMPOSING_CHAR |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4021 ? cmp_status->nchars |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4022 : cmp_status->ncomps) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4023 >= MAX_COMPOSITION_COMPONENTS) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4024 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4025 /* Too long composition. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4026 MAYBE_FINISH_COMPOSITION (); |
88365 | 4027 *charbuf++ = c; |
4028 char_offset++; | |
4029 } | |
4030 else | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4031 STORE_COMPOSITION_CHAR (c); |
17052 | 4032 continue; |
4033 | |
88365 | 4034 invalid_code: |
4035 MAYBE_FINISH_COMPOSITION (); | |
4036 src = src_base; | |
4037 consumed_chars = consumed_chars_base; | |
4038 ONE_MORE_BYTE (c); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4039 *charbuf++ = c < 0 ? -c : ASCII_BYTE_P (c) ? c : BYTE8_TO_CHAR (c); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4040 char_offset++; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4041 coding->errors++; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
4042 continue; |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
4043 |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
4044 break_loop: |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
4045 break; |
88365 | 4046 } |
4047 | |
4048 no_more_source: | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4049 if (cmp_status->state != COMPOSING_NO) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4050 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4051 if (coding->mode & CODING_MODE_LAST_BLOCK) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4052 MAYBE_FINISH_COMPOSITION (); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4053 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4054 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4055 charbuf -= cmp_status->length; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4056 for (i = 0; i < cmp_status->length; i++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4057 cmp_status->carryover[i] = charbuf[i]; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4058 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4059 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
4060 else if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4061 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
88365 | 4062 coding->consumed_char += consumed_chars_base; |
4063 coding->consumed = src_base - coding->source; | |
4064 coding->charbuf_used = charbuf - coding->charbuf; | |
17052 | 4065 } |
4066 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4067 |
18766 | 4068 /* ISO2022 encoding stuff. */ |
17052 | 4069 |
4070 /* | |
18766 | 4071 It is not enough to say just "ISO2022" on encoding, we have to |
88365 | 4072 specify more details. In Emacs, each coding system of ISO2022 |
17052 | 4073 variant has the following specifications: |
88365 | 4074 1. Initial designation to G0 thru G3. |
17052 | 4075 2. Allows short-form designation? |
4076 3. ASCII should be designated to G0 before control characters? | |
4077 4. ASCII should be designated to G0 at end of line? | |
4078 5. 7-bit environment or 8-bit environment? | |
4079 6. Use locking-shift? | |
4080 7. Use Single-shift? | |
4081 And the following two are only for Japanese: | |
4082 8. Use ASCII in place of JIS0201-1976-Roman? | |
4083 9. Use JISX0208-1983 in place of JISX0208-1978? | |
88365 | 4084 These specifications are encoded in CODING_ISO_FLAGS (coding) as flag bits |
4085 defined by macros CODING_ISO_FLAG_XXX. See `coding.h' for more | |
18766 | 4086 details. |
17052 | 4087 */ |
4088 | |
4089 /* Produce codes (escape sequence) for designating CHARSET to graphic | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4090 register REG at DST, and increment DST. If <final-char> of CHARSET is |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4091 '@', 'A', or 'B' and the coding system CODING allows, produce |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4092 designation sequence of short-form. */ |
17052 | 4093 |
4094 #define ENCODE_DESIGNATION(charset, reg, coding) \ | |
4095 do { \ | |
88365 | 4096 unsigned char final_char = CHARSET_ISO_FINAL (charset); \ |
109717
8949aad5e992
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109573
diff
changeset
|
4097 const char *intermediate_char_94 = "()*+"; \ |
8949aad5e992
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109573
diff
changeset
|
4098 const char *intermediate_char_96 = ",-./"; \ |
88365 | 4099 int revision = -1; \ |
4100 int c; \ | |
4101 \ | |
4102 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_REVISION) \ | |
88856 | 4103 revision = CHARSET_ISO_REVISION (charset); \ |
88365 | 4104 \ |
4105 if (revision >= 0) \ | |
20150
402b6e5f4b58
(encode_designation_at_bol): Fix bug of finding graphic
Kenichi Handa <handa@m17n.org>
parents:
20105
diff
changeset
|
4106 { \ |
88365 | 4107 EMIT_TWO_ASCII_BYTES (ISO_CODE_ESC, '&'); \ |
4108 EMIT_ONE_BYTE ('@' + revision); \ | |
17052 | 4109 } \ |
88365 | 4110 EMIT_ONE_ASCII_BYTE (ISO_CODE_ESC); \ |
17052 | 4111 if (CHARSET_DIMENSION (charset) == 1) \ |
4112 { \ | |
88365 | 4113 if (! CHARSET_ISO_CHARS_96 (charset)) \ |
4114 c = intermediate_char_94[reg]; \ | |
17052 | 4115 else \ |
88365 | 4116 c = intermediate_char_96[reg]; \ |
4117 EMIT_ONE_ASCII_BYTE (c); \ | |
17052 | 4118 } \ |
4119 else \ | |
4120 { \ | |
88365 | 4121 EMIT_ONE_ASCII_BYTE ('$'); \ |
4122 if (! CHARSET_ISO_CHARS_96 (charset)) \ | |
17052 | 4123 { \ |
88365 | 4124 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_LONG_FORM \ |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4125 || reg != 0 \ |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4126 || final_char < '@' || final_char > 'B') \ |
88365 | 4127 EMIT_ONE_ASCII_BYTE (intermediate_char_94[reg]); \ |
17052 | 4128 } \ |
4129 else \ | |
88365 | 4130 EMIT_ONE_ASCII_BYTE (intermediate_char_96[reg]); \ |
17052 | 4131 } \ |
88365 | 4132 EMIT_ONE_ASCII_BYTE (final_char); \ |
4133 \ | |
4134 CODING_ISO_DESIGNATION (coding, reg) = CHARSET_ID (charset); \ | |
17052 | 4135 } while (0) |
4136 | |
88365 | 4137 |
17052 | 4138 /* The following two macros produce codes (control character or escape |
4139 sequence) for ISO2022 single-shift functions (single-shift-2 and | |
4140 single-shift-3). */ | |
4141 | |
88365 | 4142 #define ENCODE_SINGLE_SHIFT_2 \ |
4143 do { \ | |
4144 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS) \ | |
4145 EMIT_TWO_ASCII_BYTES (ISO_CODE_ESC, 'N'); \ | |
4146 else \ | |
4147 EMIT_ONE_BYTE (ISO_CODE_SS2); \ | |
4148 CODING_ISO_SINGLE_SHIFTING (coding) = 1; \ | |
17052 | 4149 } while (0) |
4150 | |
88365 | 4151 |
4152 #define ENCODE_SINGLE_SHIFT_3 \ | |
4153 do { \ | |
4154 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS) \ | |
4155 EMIT_TWO_ASCII_BYTES (ISO_CODE_ESC, 'O'); \ | |
4156 else \ | |
4157 EMIT_ONE_BYTE (ISO_CODE_SS3); \ | |
4158 CODING_ISO_SINGLE_SHIFTING (coding) = 1; \ | |
17052 | 4159 } while (0) |
4160 | |
88365 | 4161 |
17052 | 4162 /* The following four macros produce codes (control character or |
4163 escape sequence) for ISO2022 locking-shift functions (shift-in, | |
4164 shift-out, locking-shift-2, and locking-shift-3). */ | |
4165 | |
88365 | 4166 #define ENCODE_SHIFT_IN \ |
4167 do { \ | |
4168 EMIT_ONE_ASCII_BYTE (ISO_CODE_SI); \ | |
4169 CODING_ISO_INVOCATION (coding, 0) = 0; \ | |
17052 | 4170 } while (0) |
4171 | |
88365 | 4172 |
4173 #define ENCODE_SHIFT_OUT \ | |
4174 do { \ | |
4175 EMIT_ONE_ASCII_BYTE (ISO_CODE_SO); \ | |
4176 CODING_ISO_INVOCATION (coding, 0) = 1; \ | |
17052 | 4177 } while (0) |
4178 | |
88365 | 4179 |
4180 #define ENCODE_LOCKING_SHIFT_2 \ | |
4181 do { \ | |
4182 EMIT_TWO_ASCII_BYTES (ISO_CODE_ESC, 'n'); \ | |
4183 CODING_ISO_INVOCATION (coding, 0) = 2; \ | |
17052 | 4184 } while (0) |
4185 | |
88365 | 4186 |
4187 #define ENCODE_LOCKING_SHIFT_3 \ | |
4188 do { \ | |
4189 EMIT_TWO_ASCII_BYTES (ISO_CODE_ESC, 'n'); \ | |
4190 CODING_ISO_INVOCATION (coding, 0) = 3; \ | |
17052 | 4191 } while (0) |
4192 | |
88365 | 4193 |
18766 | 4194 /* Produce codes for a DIMENSION1 character whose character set is |
4195 CHARSET and whose position-code is C1. Designation and invocation | |
17052 | 4196 sequences are also produced in advance if necessary. */ |
4197 | |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4198 #define ENCODE_ISO_CHARACTER_DIMENSION1(charset, c1) \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4199 do { \ |
88365 | 4200 int id = CHARSET_ID (charset); \ |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4201 \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4202 if ((CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_USE_ROMAN) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4203 && id == charset_ascii) \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4204 { \ |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4205 id = charset_jisx0201_roman; \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4206 charset = CHARSET_FROM_ID (id); \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4207 } \ |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4208 \ |
88365 | 4209 if (CODING_ISO_SINGLE_SHIFTING (coding)) \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4210 { \ |
88365 | 4211 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS) \ |
4212 EMIT_ONE_ASCII_BYTE (c1 & 0x7F); \ | |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4213 else \ |
88365 | 4214 EMIT_ONE_BYTE (c1 | 0x80); \ |
4215 CODING_ISO_SINGLE_SHIFTING (coding) = 0; \ | |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4216 break; \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4217 } \ |
88365 | 4218 else if (id == CODING_ISO_INVOKED_CHARSET (coding, 0)) \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4219 { \ |
88365 | 4220 EMIT_ONE_ASCII_BYTE (c1 & 0x7F); \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4221 break; \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4222 } \ |
88365 | 4223 else if (id == CODING_ISO_INVOKED_CHARSET (coding, 1)) \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4224 { \ |
88365 | 4225 EMIT_ONE_BYTE (c1 | 0x80); \ |
19285
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4226 break; \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4227 } \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4228 else \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4229 /* Since CHARSET is not yet invoked to any graphic planes, we \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4230 must invoke it, or, at first, designate it to some graphic \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4231 register. Then repeat the loop to actually produce the \ |
af3d00fde172
(Fset_terminal_coding_system_internal): Set
Kenichi Handa <handa@m17n.org>
parents:
19280
diff
changeset
|
4232 character. */ \ |
88365 | 4233 dst = encode_invocation_designation (charset, coding, dst, \ |
4234 &produced_chars); \ | |
17052 | 4235 } while (1) |
4236 | |
88365 | 4237 |
4238 /* Produce codes for a DIMENSION2 character whose character set is | |
4239 CHARSET and whose position-codes are C1 and C2. Designation and | |
4240 invocation codes are also produced in advance if necessary. */ | |
4241 | |
4242 #define ENCODE_ISO_CHARACTER_DIMENSION2(charset, c1, c2) \ | |
24506
219c99669e4b
(ENCODE_ISO_CHARACTER): Check validity of CHARSET. If
Kenichi Handa <handa@m17n.org>
parents:
24460
diff
changeset
|
4243 do { \ |
88365 | 4244 int id = CHARSET_ID (charset); \ |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4245 \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4246 if ((CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_USE_OLDJIS) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4247 && id == charset_jisx0208) \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4248 { \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4249 id = charset_jisx0208_1978; \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4250 charset = CHARSET_FROM_ID (id); \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4251 } \ |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4252 \ |
88365 | 4253 if (CODING_ISO_SINGLE_SHIFTING (coding)) \ |
4254 { \ | |
4255 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS) \ | |
4256 EMIT_TWO_ASCII_BYTES ((c1) & 0x7F, (c2) & 0x7F); \ | |
4257 else \ | |
4258 EMIT_TWO_BYTES ((c1) | 0x80, (c2) | 0x80); \ | |
4259 CODING_ISO_SINGLE_SHIFTING (coding) = 0; \ | |
4260 break; \ | |
4261 } \ | |
4262 else if (id == CODING_ISO_INVOKED_CHARSET (coding, 0)) \ | |
4263 { \ | |
4264 EMIT_TWO_ASCII_BYTES ((c1) & 0x7F, (c2) & 0x7F); \ | |
4265 break; \ | |
4266 } \ | |
4267 else if (id == CODING_ISO_INVOKED_CHARSET (coding, 1)) \ | |
4268 { \ | |
4269 EMIT_TWO_BYTES ((c1) | 0x80, (c2) | 0x80); \ | |
4270 break; \ | |
4271 } \ | |
4272 else \ | |
4273 /* Since CHARSET is not yet invoked to any graphic planes, we \ | |
4274 must invoke it, or, at first, designate it to some graphic \ | |
4275 register. Then repeat the loop to actually produce the \ | |
4276 character. */ \ | |
4277 dst = encode_invocation_designation (charset, coding, dst, \ | |
4278 &produced_chars); \ | |
4279 } while (1) | |
4280 | |
4281 | |
4282 #define ENCODE_ISO_CHARACTER(charset, c) \ | |
4283 do { \ | |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
4284 int code = ENCODE_CHAR ((charset), (c)); \ |
88365 | 4285 \ |
4286 if (CHARSET_DIMENSION (charset) == 1) \ | |
4287 ENCODE_ISO_CHARACTER_DIMENSION1 ((charset), code); \ | |
4288 else \ | |
4289 ENCODE_ISO_CHARACTER_DIMENSION2 ((charset), code >> 8, code & 0xFF); \ | |
22119
592bb8b9bcfd
Change terms unify/unification to
Kenichi Handa <handa@m17n.org>
parents:
22020
diff
changeset
|
4290 } while (0) |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4291 |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
4292 |
17052 | 4293 /* Produce designation and invocation codes at a place pointed by DST |
88365 | 4294 to use CHARSET. The element `spec.iso_2022' of *CODING is updated. |
17052 | 4295 Return new DST. */ |
4296 | |
4297 unsigned char * | |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4298 encode_invocation_designation (struct charset *charset, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4299 struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4300 unsigned char *dst, int *p_nchars) |
17052 | 4301 { |
88365 | 4302 int multibytep = coding->dst_multibyte; |
4303 int produced_chars = *p_nchars; | |
17052 | 4304 int reg; /* graphic register number */ |
88365 | 4305 int id = CHARSET_ID (charset); |
17052 | 4306 |
4307 /* At first, check designations. */ | |
4308 for (reg = 0; reg < 4; reg++) | |
88365 | 4309 if (id == CODING_ISO_DESIGNATION (coding, reg)) |
17052 | 4310 break; |
4311 | |
4312 if (reg >= 4) | |
4313 { | |
4314 /* CHARSET is not yet designated to any graphic registers. */ | |
4315 /* At first check the requested designation. */ | |
88365 | 4316 reg = CODING_ISO_REQUEST (coding, id); |
4317 if (reg < 0) | |
18002
a14261786239
(encode_invocation_designation): Use macro
Kenichi Handa <handa@m17n.org>
parents:
17835
diff
changeset
|
4318 /* Since CHARSET requests no special designation, designate it |
a14261786239
(encode_invocation_designation): Use macro
Kenichi Handa <handa@m17n.org>
parents:
17835
diff
changeset
|
4319 to graphic register 0. */ |
17052 | 4320 reg = 0; |
4321 | |
4322 ENCODE_DESIGNATION (charset, reg, coding); | |
4323 } | |
4324 | |
88365 | 4325 if (CODING_ISO_INVOCATION (coding, 0) != reg |
4326 && CODING_ISO_INVOCATION (coding, 1) != reg) | |
17052 | 4327 { |
4328 /* Since the graphic register REG is not invoked to any graphic | |
4329 planes, invoke it to graphic plane 0. */ | |
4330 switch (reg) | |
4331 { | |
4332 case 0: /* graphic register 0 */ | |
4333 ENCODE_SHIFT_IN; | |
4334 break; | |
4335 | |
4336 case 1: /* graphic register 1 */ | |
4337 ENCODE_SHIFT_OUT; | |
4338 break; | |
4339 | |
4340 case 2: /* graphic register 2 */ | |
88365 | 4341 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT) |
17052 | 4342 ENCODE_SINGLE_SHIFT_2; |
4343 else | |
4344 ENCODE_LOCKING_SHIFT_2; | |
4345 break; | |
4346 | |
4347 case 3: /* graphic register 3 */ | |
88365 | 4348 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT) |
17052 | 4349 ENCODE_SINGLE_SHIFT_3; |
4350 else | |
4351 ENCODE_LOCKING_SHIFT_3; | |
4352 break; | |
4353 } | |
4354 } | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4355 |
88365 | 4356 *p_nchars = produced_chars; |
17052 | 4357 return dst; |
4358 } | |
4359 | |
4360 /* The following three macros produce codes for indicating direction | |
4361 of text. */ | |
88365 | 4362 #define ENCODE_CONTROL_SEQUENCE_INTRODUCER \ |
4363 do { \ | |
4364 if (CODING_ISO_FLAGS (coding) == CODING_ISO_FLAG_SEVEN_BITS) \ | |
4365 EMIT_TWO_ASCII_BYTES (ISO_CODE_ESC, '['); \ | |
4366 else \ | |
4367 EMIT_ONE_BYTE (ISO_CODE_CSI); \ | |
17052 | 4368 } while (0) |
4369 | |
88365 | 4370 |
4371 #define ENCODE_DIRECTION_R2L() \ | |
4372 do { \ | |
4373 ENCODE_CONTROL_SEQUENCE_INTRODUCER (dst); \ | |
4374 EMIT_TWO_ASCII_BYTES ('2', ']'); \ | |
4375 } while (0) | |
4376 | |
4377 | |
4378 #define ENCODE_DIRECTION_L2R() \ | |
4379 do { \ | |
4380 ENCODE_CONTROL_SEQUENCE_INTRODUCER (dst); \ | |
4381 EMIT_TWO_ASCII_BYTES ('0', ']'); \ | |
4382 } while (0) | |
4383 | |
17052 | 4384 |
4385 /* Produce codes for designation and invocation to reset the graphic | |
4386 planes and registers to initial state. */ | |
88365 | 4387 #define ENCODE_RESET_PLANE_AND_REGISTER() \ |
4388 do { \ | |
4389 int reg; \ | |
4390 struct charset *charset; \ | |
4391 \ | |
4392 if (CODING_ISO_INVOCATION (coding, 0) != 0) \ | |
4393 ENCODE_SHIFT_IN; \ | |
4394 for (reg = 0; reg < 4; reg++) \ | |
4395 if (CODING_ISO_INITIAL (coding, reg) >= 0 \ | |
4396 && (CODING_ISO_DESIGNATION (coding, reg) \ | |
4397 != CODING_ISO_INITIAL (coding, reg))) \ | |
4398 { \ | |
4399 charset = CHARSET_FROM_ID (CODING_ISO_INITIAL (coding, reg)); \ | |
4400 ENCODE_DESIGNATION (charset, reg, coding); \ | |
4401 } \ | |
17052 | 4402 } while (0) |
4403 | |
88365 | 4404 |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4405 /* Produce designation sequences of charsets in the line started from |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4406 SRC to a place pointed by DST, and return updated DST. |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4407 |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4408 If the current block ends before any end-of-line, we may fail to |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
4409 find all the necessary designations. */ |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
4410 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4411 static unsigned char * |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4412 encode_designation_at_bol (struct coding_system *coding, int *charbuf, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4413 int *charbuf_end, unsigned char *dst) |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4414 { |
88365 | 4415 struct charset *charset; |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4416 /* Table of charsets to be designated to each graphic register. */ |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4417 int r[4]; |
88365 | 4418 int c, found = 0, reg; |
4419 int produced_chars = 0; | |
4420 int multibytep = coding->dst_multibyte; | |
4421 Lisp_Object attrs; | |
4422 Lisp_Object charset_list; | |
4423 | |
4424 attrs = CODING_ID_ATTRS (coding->id); | |
4425 charset_list = CODING_ATTR_CHARSET_LIST (attrs); | |
4426 if (EQ (charset_list, Qiso_2022)) | |
4427 charset_list = Viso_2022_charset_list; | |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4428 |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4429 for (reg = 0; reg < 4; reg++) |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4430 r[reg] = -1; |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4431 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4432 while (found < 4) |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4433 { |
88365 | 4434 int id; |
4435 | |
4436 c = *charbuf++; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4437 if (c == '\n') |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4438 break; |
88365 | 4439 charset = char_charset (c, charset_list, NULL); |
4440 id = CHARSET_ID (charset); | |
4441 reg = CODING_ISO_REQUEST (coding, id); | |
4442 if (reg >= 0 && r[reg] < 0) | |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4443 { |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4444 found++; |
88365 | 4445 r[reg] = id; |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4446 } |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4447 } |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4448 |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4449 if (found) |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4450 { |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4451 for (reg = 0; reg < 4; reg++) |
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4452 if (r[reg] >= 0 |
88365 | 4453 && CODING_ISO_DESIGNATION (coding, reg) != r[reg]) |
4454 ENCODE_DESIGNATION (CHARSET_FROM_ID (r[reg]), reg, coding); | |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4455 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4456 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4457 return dst; |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4458 } |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4459 |
17052 | 4460 /* See the above "GENERAL NOTES on `encode_coding_XXX ()' functions". */ |
4461 | |
88365 | 4462 static int |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
4463 encode_coding_iso_2022 (struct coding_system *coding) |
17052 | 4464 { |
88365 | 4465 int multibytep = coding->dst_multibyte; |
4466 int *charbuf = coding->charbuf; | |
4467 int *charbuf_end = charbuf + coding->charbuf_used; | |
4468 unsigned char *dst = coding->destination + coding->produced; | |
4469 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
4470 int safe_room = 16; | |
4471 int bol_designation | |
4472 = (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_DESIGNATE_AT_BOL | |
4473 && CODING_ISO_BOL (coding)); | |
4474 int produced_chars = 0; | |
4475 Lisp_Object attrs, eol_type, charset_list; | |
4476 int ascii_compatible; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4477 int c; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4478 int preferred_charset_id = -1; |
88365 | 4479 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4480 CODING_GET_INFO (coding, attrs, charset_list); |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
4481 eol_type = inhibit_eol_conversion ? Qunix : CODING_ID_EOL_TYPE (coding->id); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4482 if (VECTORP (eol_type)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4483 eol_type = Qunix; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4484 |
88497
d2b9e0d4c2f6
(Fdecode_sjis_char): Fix typo (0x7F->0xFF). Fix the
Kenichi Handa <handa@m17n.org>
parents:
88485
diff
changeset
|
4485 setup_iso_safe_charsets (attrs); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4486 /* Charset list may have been changed. */ |
90772
b15334b4a9c3
(coding_alloc_by_making_gap): New arg offset.
Kenichi Handa <handa@m17n.org>
parents:
90737
diff
changeset
|
4487 charset_list = CODING_ATTR_CHARSET_LIST (attrs); |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
4488 coding->safe_charsets = SDATA (CODING_ATTR_SAFE_CHARSETS (attrs)); |
88365 | 4489 |
110336
3ffb3b102dae
coding.c (encode_coding_iso_2022): Do not optimize for ASCII if we may use designation or locking-shift.
Kenichi Handa <handa@m17n.org>
parents:
110334
diff
changeset
|
4490 ascii_compatible |
3ffb3b102dae
coding.c (encode_coding_iso_2022): Do not optimize for ASCII if we may use designation or locking-shift.
Kenichi Handa <handa@m17n.org>
parents:
110334
diff
changeset
|
4491 = (! NILP (CODING_ATTR_ASCII_COMPAT (attrs)) |
3ffb3b102dae
coding.c (encode_coding_iso_2022): Do not optimize for ASCII if we may use designation or locking-shift.
Kenichi Handa <handa@m17n.org>
parents:
110334
diff
changeset
|
4492 && ! (CODING_ISO_FLAGS (coding) & (CODING_ISO_FLAG_DESIGNATION |
3ffb3b102dae
coding.c (encode_coding_iso_2022): Do not optimize for ASCII if we may use designation or locking-shift.
Kenichi Handa <handa@m17n.org>
parents:
110334
diff
changeset
|
4493 | CODING_ISO_FLAG_LOCKING_SHIFT))); |
88365 | 4494 |
4495 while (charbuf < charbuf_end) | |
4496 { | |
4497 ASSURE_DESTINATION (safe_room); | |
4498 | |
4499 if (bol_designation) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4500 { |
88365 | 4501 unsigned char *dst_prev = dst; |
4502 | |
17725
92f042f73be2
(Valternate_charset_table): The valiable deleted.
Kenichi Handa <handa@m17n.org>
parents:
17717
diff
changeset
|
4503 /* We have to produce designation sequences if any now. */ |
88365 | 4504 dst = encode_designation_at_bol (coding, charbuf, charbuf_end, dst); |
4505 bol_designation = 0; | |
4506 /* We are sure that designation sequences are all ASCII bytes. */ | |
4507 produced_chars += dst - dst_prev; | |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4508 } |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
4509 |
88365 | 4510 c = *charbuf++; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4511 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4512 if (c < 0) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4513 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4514 /* Handle an annotation. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4515 switch (*charbuf) |
17052 | 4516 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4517 case CODING_ANNOTATE_COMPOSITION_MASK: |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4518 /* Not yet implemented. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4519 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4520 case CODING_ANNOTATE_CHARSET_MASK: |
90014
ade0c9a12f99
(encode_coding_iso_2022): Fix handling of charset
Kenichi Handa <handa@m17n.org>
parents:
90011
diff
changeset
|
4521 preferred_charset_id = charbuf[2]; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4522 if (preferred_charset_id >= 0 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4523 && NILP (Fmemq (make_number (preferred_charset_id), |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4524 charset_list))) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4525 preferred_charset_id = -1; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4526 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4527 default: |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4528 abort (); |
26847 | 4529 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4530 charbuf += -c - 1; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4531 continue; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4532 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4533 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4534 /* Now encode the character C. */ |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4535 if (c < 0x20 || c == 0x7F) |
17052 | 4536 { |
88365 | 4537 if (c == '\n' |
4538 || (c == '\r' && EQ (eol_type, Qmac))) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4539 { |
88365 | 4540 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_RESET_AT_EOL) |
4541 ENCODE_RESET_PLANE_AND_REGISTER (); | |
4542 if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_INIT_AT_BOL) | |
4543 { | |
4544 int i; | |
4545 | |
4546 for (i = 0; i < 4; i++) | |
4547 CODING_ISO_DESIGNATION (coding, i) | |
4548 = CODING_ISO_INITIAL (coding, i); | |
4549 } | |
4550 bol_designation | |
4551 = CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_DESIGNATE_AT_BOL; | |
19052
302a7b2a6948
(encode_coding_iso2022): Write out invalid multibyte
Kenichi Handa <handa@m17n.org>
parents:
18910
diff
changeset
|
4552 } |
88365 | 4553 else if (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_RESET_AT_CNTL) |
4554 ENCODE_RESET_PLANE_AND_REGISTER (); | |
4555 EMIT_ONE_ASCII_BYTE (c); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4556 } |
88365 | 4557 else if (ASCII_CHAR_P (c)) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4558 { |
88365 | 4559 if (ascii_compatible) |
4560 EMIT_ONE_ASCII_BYTE (c); | |
4561 else | |
88681
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4562 { |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4563 struct charset *charset = CHARSET_FROM_ID (charset_ascii); |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4564 ENCODE_ISO_CHARACTER (charset, c); |
2cdfbffa8a0d
(CODING_ISO_FLAG_USE_ROMAN): New macro
Kenichi Handa <handa@m17n.org>
parents:
88669
diff
changeset
|
4565 } |
17052 | 4566 } |
88690
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
4567 else if (CHAR_BYTE8_P (c)) |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
4568 { |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
4569 c = CHAR_TO_BYTE8 (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
4570 EMIT_ONE_BYTE (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
4571 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4572 else |
88365 | 4573 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4574 struct charset *charset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4575 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4576 if (preferred_charset_id >= 0) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4577 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4578 charset = CHARSET_FROM_ID (preferred_charset_id); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4579 if (! CHAR_CHARSET_P (c, charset)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4580 charset = char_charset (c, charset_list, NULL); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4581 } |
42104
d69c2368e549
(DECODE_COMPOSITION_END): Fixed a typo in the last
Sam Steingold <sds@gnu.org>
parents:
42103
diff
changeset
|
4582 else |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4583 charset = char_charset (c, charset_list, NULL); |
88365 | 4584 if (!charset) |
17052 | 4585 { |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4586 if (coding->mode & CODING_MODE_SAFE_ENCODING) |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4587 { |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4588 c = CODING_INHIBIT_CHARACTER_SUBSTITUTION; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4589 charset = CHARSET_FROM_ID (charset_ascii); |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4590 } |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4591 else |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4592 { |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4593 c = coding->default_char; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4594 charset = char_charset (c, charset_list, NULL); |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
4595 } |
19052
302a7b2a6948
(encode_coding_iso2022): Write out invalid multibyte
Kenichi Handa <handa@m17n.org>
parents:
18910
diff
changeset
|
4596 } |
88365 | 4597 ENCODE_ISO_CHARACTER (charset, c); |
4598 } | |
4599 } | |
4600 | |
4601 if (coding->mode & CODING_MODE_LAST_BLOCK | |
4602 && CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_RESET_AT_EOL) | |
4603 { | |
4604 ASSURE_DESTINATION (safe_room); | |
4605 ENCODE_RESET_PLANE_AND_REGISTER (); | |
4606 } | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4607 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 4608 CODING_ISO_BOL (coding) = bol_designation; |
4609 coding->produced_char += produced_chars; | |
4610 coding->produced = dst - coding->destination; | |
4611 return 0; | |
17052 | 4612 } |
4613 | |
4614 | |
88365 | 4615 /*** 8,9. SJIS and BIG5 handlers ***/ |
4616 | |
4617 /* Although SJIS and BIG5 are not ISO's coding system, they are used | |
17052 | 4618 quite widely. So, for the moment, Emacs supports them in the bare |
4619 C code. But, in the future, they may be supported only by CCL. */ | |
4620 | |
4621 /* SJIS is a coding system encoding three character sets: ASCII, right | |
4622 half of JISX0201-Kana, and JISX0208. An ASCII character is encoded | |
4623 as is. A character of charset katakana-jisx0201 is encoded by | |
4624 "position-code + 0x80". A character of charset japanese-jisx0208 | |
4625 is encoded in 2-byte but two position-codes are divided and shifted | |
88365 | 4626 so that it fit in the range below. |
17052 | 4627 |
4628 --- CODE RANGE of SJIS --- | |
4629 (character set) (range) | |
4630 ASCII 0x00 .. 0x7F | |
88365 | 4631 KATAKANA-JISX0201 0xA0 .. 0xDF |
24324
2eec590faf26
(Fdecode_sjis_char, Fencode_sjis_char): Hanlde
Kenichi Handa <handa@m17n.org>
parents:
24316
diff
changeset
|
4632 JISX0208 (1st byte) 0x81 .. 0x9F and 0xE0 .. 0xEF |
23564
6eb3e346d1fd
(DECODE_CHARACTER_ASCII): Check validity of inserted
Kenichi Handa <handa@m17n.org>
parents:
23542
diff
changeset
|
4633 (2nd byte) 0x40 .. 0x7E and 0x80 .. 0xFC |
17052 | 4634 ------------------------------- |
4635 | |
4636 */ | |
4637 | |
4638 /* BIG5 is a coding system encoding two character sets: ASCII and | |
4639 Big5. An ASCII character is encoded as is. Big5 is a two-byte | |
88365 | 4640 character set and is encoded in two-byte. |
17052 | 4641 |
4642 --- CODE RANGE of BIG5 --- | |
4643 (character set) (range) | |
4644 ASCII 0x00 .. 0x7F | |
4645 Big5 (1st byte) 0xA1 .. 0xFE | |
4646 (2nd byte) 0x40 .. 0x7E and 0xA1 .. 0xFE | |
4647 -------------------------- | |
4648 | |
88365 | 4649 */ |
17052 | 4650 |
4651 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". | |
4652 Check if a text is encoded in SJIS. If it is, return | |
88365 | 4653 CATEGORY_MASK_SJIS, else return 0. */ |
17052 | 4654 |
34531
37f85e931855
(ONE_MORE_BYTE_CHECK_MULTIBYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34197
diff
changeset
|
4655 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4656 detect_coding_sjis (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4657 struct coding_detection_info *detect_info) |
17052 | 4658 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4659 const unsigned char *src = coding->source, *src_base; |
89483 | 4660 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 4661 int multibytep = coding->src_multibyte; |
4662 int consumed_chars = 0; | |
4663 int found = 0; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4664 int c; |
103762
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4665 Lisp_Object attrs, charset_list; |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4666 int max_first_byte_of_2_byte_code; |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4667 |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4668 CODING_GET_INFO (coding, attrs, charset_list); |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4669 max_first_byte_of_2_byte_code |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4670 = (XINT (Flength (charset_list)) > 3 ? 0xFC : 0xEF); |
88365 | 4671 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4672 detect_info->checked |= CATEGORY_MASK_SJIS; |
88365 | 4673 /* A coding system of this category is always ASCII compatible. */ |
4674 src += coding->head_ascii; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4675 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4676 while (1) |
17052 | 4677 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4678 src_base = src; |
88365 | 4679 ONE_MORE_BYTE (c); |
36647
0a75ccbe42b2
(detect_coding_sjis): Do more rigid check.
Kenichi Handa <handa@m17n.org>
parents:
36520
diff
changeset
|
4680 if (c < 0x80) |
0a75ccbe42b2
(detect_coding_sjis): Do more rigid check.
Kenichi Handa <handa@m17n.org>
parents:
36520
diff
changeset
|
4681 continue; |
103762
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4682 if ((c >= 0x81 && c <= 0x9F) |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
4683 || (c >= 0xE0 && c <= max_first_byte_of_2_byte_code)) |
17052 | 4684 { |
88365 | 4685 ONE_MORE_BYTE (c); |
36647
0a75ccbe42b2
(detect_coding_sjis): Do more rigid check.
Kenichi Handa <handa@m17n.org>
parents:
36520
diff
changeset
|
4686 if (c < 0x40 || c == 0x7F || c > 0xFC) |
88365 | 4687 break; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4688 found = CATEGORY_MASK_SJIS; |
17052 | 4689 } |
88365 | 4690 else if (c >= 0xA0 && c < 0xE0) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4691 found = CATEGORY_MASK_SJIS; |
88365 | 4692 else |
4693 break; | |
4694 } | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4695 detect_info->rejected |= CATEGORY_MASK_SJIS; |
88365 | 4696 return 0; |
4697 | |
4698 no_more_source: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4699 if (src_base < src && coding->mode & CODING_MODE_LAST_BLOCK) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4700 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4701 detect_info->rejected |= CATEGORY_MASK_SJIS; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4702 return 0; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4703 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4704 detect_info->found |= found; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4705 return 1; |
17052 | 4706 } |
4707 | |
4708 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". | |
4709 Check if a text is encoded in BIG5. If it is, return | |
88365 | 4710 CATEGORY_MASK_BIG5, else return 0. */ |
17052 | 4711 |
34531
37f85e931855
(ONE_MORE_BYTE_CHECK_MULTIBYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34197
diff
changeset
|
4712 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4713 detect_coding_big5 (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
4714 struct coding_detection_info *detect_info) |
17052 | 4715 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4716 const unsigned char *src = coding->source, *src_base; |
89483 | 4717 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 4718 int multibytep = coding->src_multibyte; |
4719 int consumed_chars = 0; | |
4720 int found = 0; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4721 int c; |
88365 | 4722 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4723 detect_info->checked |= CATEGORY_MASK_BIG5; |
88365 | 4724 /* A coding system of this category is always ASCII compatible. */ |
4725 src += coding->head_ascii; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4726 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4727 while (1) |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4728 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4729 src_base = src; |
88365 | 4730 ONE_MORE_BYTE (c); |
4731 if (c < 0x80) | |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4732 continue; |
88365 | 4733 if (c >= 0xA1) |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4734 { |
88365 | 4735 ONE_MORE_BYTE (c); |
4736 if (c < 0x40 || (c >= 0x7F && c <= 0xA0)) | |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4737 return 0; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4738 found = CATEGORY_MASK_BIG5; |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4739 } |
88365 | 4740 else |
4741 break; | |
4742 } | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4743 detect_info->rejected |= CATEGORY_MASK_BIG5; |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4744 return 0; |
88365 | 4745 |
4746 no_more_source: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4747 if (src_base < src && coding->mode & CODING_MODE_LAST_BLOCK) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4748 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4749 detect_info->rejected |= CATEGORY_MASK_BIG5; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4750 return 0; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4751 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4752 detect_info->found |= found; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4753 return 1; |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4754 } |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
4755 |
17052 | 4756 /* See the above "GENERAL NOTES on `decode_coding_XXX ()' functions". |
4757 If SJIS_P is 1, decode SJIS text, else decode BIG5 test. */ | |
4758 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4759 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
4760 decode_coding_sjis (struct coding_system *coding) |
17052 | 4761 { |
89483 | 4762 const unsigned char *src = coding->source + coding->consumed; |
4763 const unsigned char *src_end = coding->source + coding->src_bytes; | |
59168
0345f2b10f1d
(decode_coding_XXX, decode_composition_emacs_mule)
Dan Nicolaescu <dann@ics.uci.edu>
parents:
59095
diff
changeset
|
4764 const unsigned char *src_base; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4765 int *charbuf = coding->charbuf + coding->charbuf_used; |
110983 | 4766 /* We may produce one charset annotation in one loop and one more at |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
4767 the end. */ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4768 int *charbuf_end |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
4769 = coding->charbuf + coding->charbuf_size - (MAX_ANNOTATION_LENGTH * 2); |
88365 | 4770 int consumed_chars = 0, consumed_chars_base; |
4771 int multibytep = coding->src_multibyte; | |
4772 struct charset *charset_roman, *charset_kanji, *charset_kana; | |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4773 struct charset *charset_kanji2; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4774 Lisp_Object attrs, charset_list, val; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4775 int char_offset = coding->produced_char; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4776 int last_offset = char_offset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4777 int last_id = charset_ascii; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
4778 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
4779 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4780 int byte_after_cr = -1; |
88365 | 4781 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4782 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 4783 |
4784 val = charset_list; | |
4785 charset_roman = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
4786 charset_kana = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4787 charset_kanji = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4788 charset_kanji2 = NILP (val) ? NULL : CHARSET_FROM_ID (XINT (XCAR (val))); |
88365 | 4789 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4790 while (1) |
17052 | 4791 { |
88365 | 4792 int c, c1; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4793 struct charset *charset; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4794 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4795 src_base = src; |
88365 | 4796 consumed_chars_base = consumed_chars; |
4797 | |
4798 if (charbuf >= charbuf_end) | |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4799 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4800 if (byte_after_cr >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4801 src_base--; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4802 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4803 } |
88365 | 4804 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4805 if (byte_after_cr >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4806 c = byte_after_cr, byte_after_cr = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4807 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4808 ONE_MORE_BYTE (c); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4809 if (c < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4810 goto invalid_code; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4811 if (c < 0x80) |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4812 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4813 if (eol_crlf && c == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4814 ONE_MORE_BYTE (byte_after_cr); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4815 charset = charset_roman; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4816 } |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4817 else if (c == 0x80 || c == 0xA0) |
89730
d8fcefca5cf6
(decode_coding_sjis): Check the first byte rigidly.
Kenichi Handa <handa@m17n.org>
parents:
89686
diff
changeset
|
4818 goto invalid_code; |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4819 else if (c >= 0xA1 && c <= 0xDF) |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4820 { |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4821 /* SJIS -> JISX0201-Kana */ |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4822 c &= 0x7F; |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4823 charset = charset_kana; |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4824 } |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4825 else if (c <= 0xEF) |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4826 { |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4827 /* SJIS -> JISX0208 */ |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4828 ONE_MORE_BYTE (c1); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4829 if (c1 < 0x40 || c1 == 0x7F || c1 > 0xFC) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4830 goto invalid_code; |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4831 c = (c << 8) | c1; |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4832 SJIS_TO_JIS (c); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4833 charset = charset_kanji; |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4834 } |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4835 else if (c <= 0xFC && charset_kanji2) |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4836 { |
89779
74c503490829
(decode_coding_sjis): Fix comment.
Kenichi Handa <handa@m17n.org>
parents:
89764
diff
changeset
|
4837 /* SJIS -> JISX0213-2 */ |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4838 ONE_MORE_BYTE (c1); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4839 if (c1 < 0x40 || c1 == 0x7F || c1 > 0xFC) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4840 goto invalid_code; |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4841 c = (c << 8) | c1; |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4842 SJIS_TO_JIS2 (c); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4843 charset = charset_kanji2; |
17052 | 4844 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4845 else |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4846 goto invalid_code; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4847 if (charset->id != charset_ascii |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4848 && last_id != charset->id) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4849 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4850 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4851 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4852 last_id = charset->id; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4853 last_offset = char_offset; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4854 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4855 CODING_DECODE_CHAR (coding, src, src_base, src_end, charset, c, c); |
88365 | 4856 *charbuf++ = c; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4857 char_offset++; |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
4858 continue; |
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
4859 |
88365 | 4860 invalid_code: |
17052 | 4861 src = src_base; |
88365 | 4862 consumed_chars = consumed_chars_base; |
4863 ONE_MORE_BYTE (c); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4864 *charbuf++ = c < 0 ? -c : BYTE8_TO_CHAR (c); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4865 char_offset++; |
88365 | 4866 coding->errors++; |
4867 } | |
4868 | |
4869 no_more_source: | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4870 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4871 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
88365 | 4872 coding->consumed_char += consumed_chars_base; |
4873 coding->consumed = src_base - coding->source; | |
4874 coding->charbuf_used = charbuf - coding->charbuf; | |
4875 } | |
4876 | |
4877 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
4878 decode_coding_big5 (struct coding_system *coding) |
88365 | 4879 { |
89483 | 4880 const unsigned char *src = coding->source + coding->consumed; |
4881 const unsigned char *src_end = coding->source + coding->src_bytes; | |
4882 const unsigned char *src_base; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4883 int *charbuf = coding->charbuf + coding->charbuf_used; |
110983 | 4884 /* We may produce one charset annotation in one loop and one more at |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
4885 the end. */ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4886 int *charbuf_end |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
4887 = coding->charbuf + coding->charbuf_size - (MAX_ANNOTATION_LENGTH * 2); |
88365 | 4888 int consumed_chars = 0, consumed_chars_base; |
4889 int multibytep = coding->src_multibyte; | |
4890 struct charset *charset_roman, *charset_big5; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4891 Lisp_Object attrs, charset_list, val; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4892 int char_offset = coding->produced_char; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4893 int last_offset = char_offset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4894 int last_id = charset_ascii; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
4895 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
4896 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4897 int byte_after_cr = -1; |
88365 | 4898 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4899 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 4900 val = charset_list; |
4901 charset_roman = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
4902 charset_big5 = CHARSET_FROM_ID (XINT (XCAR (val))); | |
4903 | |
4904 while (1) | |
4905 { | |
4906 int c, c1; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4907 struct charset *charset; |
88365 | 4908 |
4909 src_base = src; | |
4910 consumed_chars_base = consumed_chars; | |
4911 | |
4912 if (charbuf >= charbuf_end) | |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4913 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4914 if (byte_after_cr >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4915 src_base--; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4916 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
4917 } |
88365 | 4918 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4919 if (byte_after_cr >= 0) |
92406
c36bda0a03cc
(decode_coding_big5, produce_chars): Fix typos in last
Andreas Schwab <schwab@suse.de>
parents:
92399
diff
changeset
|
4920 c = byte_after_cr, byte_after_cr = -1; |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4921 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4922 ONE_MORE_BYTE (c); |
88365 | 4923 |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4924 if (c < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4925 goto invalid_code; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4926 if (c < 0x80) |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4927 { |
92406
c36bda0a03cc
(decode_coding_big5, produce_chars): Fix typos in last
Andreas Schwab <schwab@suse.de>
parents:
92399
diff
changeset
|
4928 if (eol_crlf && c == '\r') |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4929 ONE_MORE_BYTE (byte_after_cr); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4930 charset = charset_roman; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
4931 } |
88365 | 4932 else |
4933 { | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4934 /* BIG5 -> Big5 */ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4935 if (c < 0xA1 || c > 0xFE) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4936 goto invalid_code; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4937 ONE_MORE_BYTE (c1); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4938 if (c1 < 0x40 || (c1 > 0x7E && c1 < 0xA1) || c1 > 0xFE) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4939 goto invalid_code; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4940 c = c << 8 | c1; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4941 charset = charset_big5; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4942 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4943 if (charset->id != charset_ascii |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4944 && last_id != charset->id) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4945 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4946 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4947 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4948 last_id = charset->id; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4949 last_offset = char_offset; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4950 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4951 CODING_DECODE_CHAR (coding, src, src_base, src_end, charset, c, c); |
88365 | 4952 *charbuf++ = c; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4953 char_offset++; |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
4954 continue; |
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
4955 |
88365 | 4956 invalid_code: |
17052 | 4957 src = src_base; |
88365 | 4958 consumed_chars = consumed_chars_base; |
4959 ONE_MORE_BYTE (c); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
4960 *charbuf++ = c < 0 ? -c : BYTE8_TO_CHAR (c); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4961 char_offset++; |
88365 | 4962 coding->errors++; |
4963 } | |
4964 | |
4965 no_more_source: | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
4966 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
4967 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
88365 | 4968 coding->consumed_char += consumed_chars_base; |
4969 coding->consumed = src_base - coding->source; | |
4970 coding->charbuf_used = charbuf - coding->charbuf; | |
17052 | 4971 } |
4972 | |
4973 /* See the above "GENERAL NOTES on `encode_coding_XXX ()' functions". | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4974 This function can encode charsets `ascii', `katakana-jisx0201', |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4975 `japanese-jisx0208', `chinese-big5-1', and `chinese-big5-2'. We |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
4976 are sure that all these charsets are registered as official charset |
17052 | 4977 (i.e. do not have extended leading-codes). Characters of other |
4978 charsets are produced without any encoding. If SJIS_P is 1, encode | |
4979 SJIS text, else encode BIG5 text. */ | |
4980 | |
88365 | 4981 static int |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
4982 encode_coding_sjis (struct coding_system *coding) |
17052 | 4983 { |
88365 | 4984 int multibytep = coding->dst_multibyte; |
4985 int *charbuf = coding->charbuf; | |
4986 int *charbuf_end = charbuf + coding->charbuf_used; | |
4987 unsigned char *dst = coding->destination + coding->produced; | |
4988 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
4989 int safe_room = 4; | |
4990 int produced_chars = 0; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4991 Lisp_Object attrs, charset_list, val; |
88365 | 4992 int ascii_compatible; |
4993 struct charset *charset_roman, *charset_kanji, *charset_kana; | |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
4994 struct charset *charset_kanji2; |
88365 | 4995 int c; |
4996 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
4997 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 4998 val = charset_list; |
4999 charset_roman = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
5000 charset_kana = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5001 charset_kanji = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5002 charset_kanji2 = NILP (val) ? NULL : CHARSET_FROM_ID (XINT (XCAR (val))); |
88365 | 5003 |
5004 ascii_compatible = ! NILP (CODING_ATTR_ASCII_COMPAT (attrs)); | |
5005 | |
5006 while (charbuf < charbuf_end) | |
5007 { | |
5008 ASSURE_DESTINATION (safe_room); | |
5009 c = *charbuf++; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5010 /* Now encode the character C. */ |
88365 | 5011 if (ASCII_CHAR_P (c) && ascii_compatible) |
5012 EMIT_ONE_ASCII_BYTE (c); | |
88690
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5013 else if (CHAR_BYTE8_P (c)) |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5014 { |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5015 c = CHAR_TO_BYTE8 (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5016 EMIT_ONE_BYTE (c); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5017 } |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5018 else |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5019 { |
88365 | 5020 unsigned code; |
5021 struct charset *charset = char_charset (c, charset_list, &code); | |
5022 | |
5023 if (!charset) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5024 { |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5025 if (coding->mode & CODING_MODE_SAFE_ENCODING) |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5026 { |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5027 code = CODING_INHIBIT_CHARACTER_SUBSTITUTION; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5028 charset = CHARSET_FROM_ID (charset_ascii); |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5029 } |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5030 else |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5031 { |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5032 c = coding->default_char; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5033 charset = char_charset (c, charset_list, &code); |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5034 } |
88365 | 5035 } |
5036 if (code == CHARSET_INVALID_CODE (charset)) | |
5037 abort (); | |
5038 if (charset == charset_kanji) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5039 { |
88365 | 5040 int c1, c2; |
5041 JIS_TO_SJIS (code); | |
5042 c1 = code >> 8, c2 = code & 0xFF; | |
5043 EMIT_TWO_BYTES (c1, c2); | |
5044 } | |
5045 else if (charset == charset_kana) | |
5046 EMIT_ONE_BYTE (code | 0x80); | |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5047 else if (charset_kanji2 && charset == charset_kanji2) |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5048 { |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5049 int c1, c2; |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5050 |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5051 c1 = code >> 8; |
103762
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
5052 if (c1 == 0x21 || (c1 >= 0x23 && c1 <= 0x25) |
e72df94a89ca
(detect_coding_sjis): Handle shift_jis-2004 correctly.
Kenichi Handa <handa@m17n.org>
parents:
103655
diff
changeset
|
5053 || c1 == 0x28 |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5054 || (c1 >= 0x2C && c1 <= 0x2F) || c1 >= 0x6E) |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5055 { |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5056 JIS_TO_SJIS2 (code); |
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5057 c1 = code >> 8, c2 = code & 0xFF; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5058 EMIT_TWO_BYTES (c1, c2); |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5059 } |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5060 else |
89764
e3d26232ab78
(decode_coding_sjis): Handle 4th charset (typically JISX0212).
Kenichi Handa <handa@m17n.org>
parents:
89759
diff
changeset
|
5061 EMIT_ONE_ASCII_BYTE (code & 0x7F); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5062 } |
17052 | 5063 else |
88365 | 5064 EMIT_ONE_ASCII_BYTE (code & 0x7F); |
5065 } | |
5066 } | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5067 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 5068 coding->produced_char += produced_chars; |
5069 coding->produced = dst - coding->destination; | |
5070 return 0; | |
5071 } | |
5072 | |
5073 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5074 encode_coding_big5 (struct coding_system *coding) |
88365 | 5075 { |
5076 int multibytep = coding->dst_multibyte; | |
5077 int *charbuf = coding->charbuf; | |
5078 int *charbuf_end = charbuf + coding->charbuf_used; | |
5079 unsigned char *dst = coding->destination + coding->produced; | |
5080 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
5081 int safe_room = 4; | |
5082 int produced_chars = 0; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5083 Lisp_Object attrs, charset_list, val; |
88365 | 5084 int ascii_compatible; |
5085 struct charset *charset_roman, *charset_big5; | |
5086 int c; | |
5087 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5088 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 5089 val = charset_list; |
5090 charset_roman = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
5091 charset_big5 = CHARSET_FROM_ID (XINT (XCAR (val))); | |
5092 ascii_compatible = ! NILP (CODING_ATTR_ASCII_COMPAT (attrs)); | |
5093 | |
5094 while (charbuf < charbuf_end) | |
5095 { | |
5096 ASSURE_DESTINATION (safe_room); | |
5097 c = *charbuf++; | |
5098 /* Now encode the character C. */ | |
5099 if (ASCII_CHAR_P (c) && ascii_compatible) | |
5100 EMIT_ONE_ASCII_BYTE (c); | |
88690
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5101 else if (CHAR_BYTE8_P (c)) |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5102 { |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5103 c = CHAR_TO_BYTE8 (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5104 EMIT_ONE_BYTE (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5105 } |
88365 | 5106 else |
5107 { | |
5108 unsigned code; | |
5109 struct charset *charset = char_charset (c, charset_list, &code); | |
5110 | |
5111 if (! charset) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5112 { |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5113 if (coding->mode & CODING_MODE_SAFE_ENCODING) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5114 { |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5115 code = CODING_INHIBIT_CHARACTER_SUBSTITUTION; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5116 charset = CHARSET_FROM_ID (charset_ascii); |
51140
94d903190cee
(ENCODE_UNSAFE_CHARACTER): Adjusted for the name change
Kenichi Handa <handa@m17n.org>
parents:
51090
diff
changeset
|
5117 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5118 else |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5119 { |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5120 c = coding->default_char; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5121 charset = char_charset (c, charset_list, &code); |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5122 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5123 } |
88365 | 5124 if (code == CHARSET_INVALID_CODE (charset)) |
5125 abort (); | |
5126 if (charset == charset_big5) | |
5127 { | |
5128 int c1, c2; | |
5129 | |
5130 c1 = code >> 8, c2 = code & 0xFF; | |
5131 EMIT_TWO_BYTES (c1, c2); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5132 } |
17052 | 5133 else |
88365 | 5134 EMIT_ONE_ASCII_BYTE (code & 0x7F); |
17052 | 5135 } |
88365 | 5136 } |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5137 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 5138 coding->produced_char += produced_chars; |
5139 coding->produced = dst - coding->destination; | |
5140 return 0; | |
17052 | 5141 } |
5142 | |
5143 | |
88365 | 5144 /*** 10. CCL handlers ***/ |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5145 |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5146 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5147 Check if a text is encoded in a coding system of which |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5148 encoder/decoder are written in CCL program. If it is, return |
88365 | 5149 CATEGORY_MASK_CCL, else return 0. */ |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5150 |
34531
37f85e931855
(ONE_MORE_BYTE_CHECK_MULTIBYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34197
diff
changeset
|
5151 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
5152 detect_coding_ccl (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
5153 struct coding_detection_info *detect_info) |
88365 | 5154 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5155 const unsigned char *src = coding->source, *src_base; |
89483 | 5156 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 5157 int multibytep = coding->src_multibyte; |
5158 int consumed_chars = 0; | |
5159 int found = 0; | |
89848
3edfa038a435
(detect_coding_emacs_mule): Fix counting of encoded
Kenichi Handa <handa@m17n.org>
parents:
89842
diff
changeset
|
5160 unsigned char *valids; |
88365 | 5161 int head_ascii = coding->head_ascii; |
5162 Lisp_Object attrs; | |
5163 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5164 detect_info->checked |= CATEGORY_MASK_CCL; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5165 |
88365 | 5166 coding = &coding_categories[coding_category_ccl]; |
89848
3edfa038a435
(detect_coding_emacs_mule): Fix counting of encoded
Kenichi Handa <handa@m17n.org>
parents:
89842
diff
changeset
|
5167 valids = CODING_CCL_VALIDS (coding); |
88365 | 5168 attrs = CODING_ID_ATTRS (coding->id); |
5169 if (! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) | |
5170 src += head_ascii; | |
5171 | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5172 while (1) |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5173 { |
88365 | 5174 int c; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5175 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5176 src_base = src; |
88365 | 5177 ONE_MORE_BYTE (c); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5178 if (c < 0 || ! valids[c]) |
88365 | 5179 break; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5180 if ((valids[c] > 1)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5181 found = CATEGORY_MASK_CCL; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5182 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5183 detect_info->rejected |= CATEGORY_MASK_CCL; |
88365 | 5184 return 0; |
5185 | |
5186 no_more_source: | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5187 detect_info->found |= found; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5188 return 1; |
88365 | 5189 } |
5190 | |
5191 static void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5192 decode_coding_ccl (struct coding_system *coding) |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5193 { |
88876
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
5194 const unsigned char *src = coding->source + coding->consumed; |
89483 | 5195 const unsigned char *src_end = coding->source + coding->src_bytes; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
5196 int *charbuf = coding->charbuf + coding->charbuf_used; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
5197 int *charbuf_end = coding->charbuf + coding->charbuf_size; |
88365 | 5198 int consumed_chars = 0; |
5199 int multibytep = coding->src_multibyte; | |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5200 struct ccl_program *ccl = &coding->spec.ccl->ccl; |
88365 | 5201 int source_charbuf[1024]; |
107506
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5202 int source_byteidx[1025]; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5203 Lisp_Object attrs, charset_list; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5204 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5205 CODING_GET_INFO (coding, attrs, charset_list); |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5206 |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5207 while (1) |
88365 | 5208 { |
88876
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
5209 const unsigned char *p = src; |
88365 | 5210 int i = 0; |
5211 | |
5212 if (multibytep) | |
107506
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5213 { |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5214 while (i < 1024 && p < src_end) |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5215 { |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5216 source_byteidx[i] = p - src; |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5217 source_charbuf[i++] = STRING_CHAR_ADVANCE (p); |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5218 } |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5219 source_byteidx[i] = p - src; |
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5220 } |
88365 | 5221 else |
5222 while (i < 1024 && p < src_end) | |
5223 source_charbuf[i++] = *p++; | |
89483 | 5224 |
88365 | 5225 if (p == src_end && coding->mode & CODING_MODE_LAST_BLOCK) |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5226 ccl->last_block = 1; |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5227 ccl_driver (ccl, source_charbuf, charbuf, i, charbuf_end - charbuf, |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5228 charset_list); |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5229 charbuf += ccl->produced; |
107506
cd151730b160
coding.c (decode_coding_ccl): Fix previous change for the multibyte case.
Kenichi Handa <handa@m17n.org>
parents:
107323
diff
changeset
|
5230 if (multibytep) |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5231 src += source_byteidx[ccl->consumed]; |
88365 | 5232 else |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5233 src += ccl->consumed; |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5234 consumed_chars += ccl->consumed; |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5235 if (p == src_end || ccl->status != CCL_STAT_SUSPEND_BY_SRC) |
88365 | 5236 break; |
5237 } | |
5238 | |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5239 switch (ccl->status) |
88365 | 5240 { |
5241 case CCL_STAT_SUSPEND_BY_SRC: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5242 record_conversion_result (coding, CODING_RESULT_INSUFFICIENT_SRC); |
88365 | 5243 break; |
5244 case CCL_STAT_SUSPEND_BY_DST: | |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
5245 record_conversion_result (coding, CODING_RESULT_INSUFFICIENT_DST); |
88365 | 5246 break; |
5247 case CCL_STAT_QUIT: | |
5248 case CCL_STAT_INVALID_CMD: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5249 record_conversion_result (coding, CODING_RESULT_INTERRUPT); |
88365 | 5250 break; |
5251 default: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5252 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 5253 break; |
5254 } | |
5255 coding->consumed_char += consumed_chars; | |
5256 coding->consumed = src - coding->source; | |
5257 coding->charbuf_used = charbuf - coding->charbuf; | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5258 } |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5259 |
88365 | 5260 static int |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5261 encode_coding_ccl (struct coding_system *coding) |
88365 | 5262 { |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5263 struct ccl_program *ccl = &coding->spec.ccl->ccl; |
88365 | 5264 int multibytep = coding->dst_multibyte; |
5265 int *charbuf = coding->charbuf; | |
5266 int *charbuf_end = charbuf + coding->charbuf_used; | |
5267 unsigned char *dst = coding->destination + coding->produced; | |
5268 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
5269 int destination_charbuf[1024]; | |
5270 int i, produced_chars = 0; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5271 Lisp_Object attrs, charset_list; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5272 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5273 CODING_GET_INFO (coding, attrs, charset_list); |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5274 if (coding->consumed_char == coding->src_chars |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5275 && coding->mode & CODING_MODE_LAST_BLOCK) |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5276 ccl->last_block = 1; |
88365 | 5277 |
90346
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5278 while (charbuf < charbuf_end) |
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5279 { |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5280 ccl_driver (ccl, charbuf, destination_charbuf, |
90346
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5281 charbuf_end - charbuf, 1024, charset_list); |
88365 | 5282 if (multibytep) |
90346
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5283 { |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5284 ASSURE_DESTINATION (ccl->produced * 2); |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5285 for (i = 0; i < ccl->produced; i++) |
90346
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5286 EMIT_ONE_BYTE (destination_charbuf[i] & 0xFF); |
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5287 } |
88365 | 5288 else |
5289 { | |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5290 ASSURE_DESTINATION (ccl->produced); |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5291 for (i = 0; i < ccl->produced; i++) |
88365 | 5292 *dst++ = destination_charbuf[i] & 0xFF; |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5293 produced_chars += ccl->produced; |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5294 } |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5295 charbuf += ccl->consumed; |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5296 if (ccl->status == CCL_STAT_QUIT |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5297 || ccl->status == CCL_STAT_INVALID_CMD) |
90346
bba59a8cdae0
(encode_coding_ccl): Allocate destination dynamically
Kenichi Handa <handa@m17n.org>
parents:
90336
diff
changeset
|
5298 break; |
88365 | 5299 } |
5300 | |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
5301 switch (ccl->status) |
88365 | 5302 { |
5303 case CCL_STAT_SUSPEND_BY_SRC: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5304 record_conversion_result (coding, CODING_RESULT_INSUFFICIENT_SRC); |
88365 | 5305 break; |
5306 case CCL_STAT_SUSPEND_BY_DST: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5307 record_conversion_result (coding, CODING_RESULT_INSUFFICIENT_DST); |
88365 | 5308 break; |
5309 case CCL_STAT_QUIT: | |
5310 case CCL_STAT_INVALID_CMD: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5311 record_conversion_result (coding, CODING_RESULT_INTERRUPT); |
88365 | 5312 break; |
5313 default: | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5314 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 5315 break; |
5316 } | |
5317 | |
5318 coding->produced_char += produced_chars; | |
5319 coding->produced = dst - coding->destination; | |
5320 return 0; | |
5321 } | |
5322 | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5323 |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5324 |
88365 | 5325 /*** 10, 11. no-conversion handlers ***/ |
17052 | 5326 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5327 /* See the above "GENERAL NOTES on `decode_coding_XXX ()' functions". */ |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5328 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5329 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5330 decode_coding_raw_text (struct coding_system *coding) |
17052 | 5331 { |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
5332 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
5333 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5334 |
88365 | 5335 coding->chars_at_source = 1; |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5336 coding->consumed_char = coding->src_chars; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5337 coding->consumed = coding->src_bytes; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5338 if (eol_crlf && coding->source[coding->src_bytes - 1] == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5339 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5340 coding->consumed_char--; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5341 coding->consumed--; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5342 record_conversion_result (coding, CODING_RESULT_INSUFFICIENT_SRC); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5343 } |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5344 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5345 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 5346 } |
5347 | |
5348 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5349 encode_coding_raw_text (struct coding_system *coding) |
88365 | 5350 { |
5351 int multibytep = coding->dst_multibyte; | |
5352 int *charbuf = coding->charbuf; | |
5353 int *charbuf_end = coding->charbuf + coding->charbuf_used; | |
5354 unsigned char *dst = coding->destination + coding->produced; | |
5355 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
95345
0350e5efb8f7
(encode_coding_raw_text): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95344
diff
changeset
|
5356 int produced_chars = 0; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5357 int c; |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5358 |
88365 | 5359 if (multibytep) |
5360 { | |
5361 int safe_room = MAX_MULTIBYTE_LENGTH * 2; | |
5362 | |
5363 if (coding->src_multibyte) | |
5364 while (charbuf < charbuf_end) | |
5365 { | |
5366 ASSURE_DESTINATION (safe_room); | |
5367 c = *charbuf++; | |
5368 if (ASCII_CHAR_P (c)) | |
5369 EMIT_ONE_ASCII_BYTE (c); | |
5370 else if (CHAR_BYTE8_P (c)) | |
5371 { | |
5372 c = CHAR_TO_BYTE8 (c); | |
5373 EMIT_ONE_BYTE (c); | |
5374 } | |
5375 else | |
5376 { | |
5377 unsigned char str[MAX_MULTIBYTE_LENGTH], *p0 = str, *p1 = str; | |
5378 | |
5379 CHAR_STRING_ADVANCE (c, p1); | |
5380 while (p0 < p1) | |
88950
ad258ee59fbb
* coding.c (make_conversion_work_buffer): Adjusted for the change
Kenichi Handa <handa@m17n.org>
parents:
88936
diff
changeset
|
5381 { |
ad258ee59fbb
* coding.c (make_conversion_work_buffer): Adjusted for the change
Kenichi Handa <handa@m17n.org>
parents:
88936
diff
changeset
|
5382 EMIT_ONE_BYTE (*p0); |
ad258ee59fbb
* coding.c (make_conversion_work_buffer): Adjusted for the change
Kenichi Handa <handa@m17n.org>
parents:
88936
diff
changeset
|
5383 p0++; |
ad258ee59fbb
* coding.c (make_conversion_work_buffer): Adjusted for the change
Kenichi Handa <handa@m17n.org>
parents:
88936
diff
changeset
|
5384 } |
88365 | 5385 } |
5386 } | |
5387 else | |
5388 while (charbuf < charbuf_end) | |
5389 { | |
5390 ASSURE_DESTINATION (safe_room); | |
5391 c = *charbuf++; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5392 EMIT_ONE_BYTE (c); |
88365 | 5393 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5394 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5395 else |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5396 { |
88365 | 5397 if (coding->src_multibyte) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5398 { |
88365 | 5399 int safe_room = MAX_MULTIBYTE_LENGTH; |
5400 | |
5401 while (charbuf < charbuf_end) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5402 { |
88365 | 5403 ASSURE_DESTINATION (safe_room); |
5404 c = *charbuf++; | |
5405 if (ASCII_CHAR_P (c)) | |
5406 *dst++ = c; | |
5407 else if (CHAR_BYTE8_P (c)) | |
5408 *dst++ = CHAR_TO_BYTE8 (c); | |
5409 else | |
5410 CHAR_STRING_ADVANCE (c, dst); | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5411 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5412 } |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
5413 else |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5414 { |
88365 | 5415 ASSURE_DESTINATION (charbuf_end - charbuf); |
5416 while (charbuf < charbuf_end && dst < dst_end) | |
5417 *dst++ = *charbuf++; | |
89483 | 5418 } |
95353
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
5419 produced_chars = dst - (coding->destination + coding->produced); |
88365 | 5420 } |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5421 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
95345
0350e5efb8f7
(encode_coding_raw_text): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95344
diff
changeset
|
5422 coding->produced_char += produced_chars; |
88365 | 5423 coding->produced = dst - coding->destination; |
5424 return 0; | |
5425 } | |
5426 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5427 /* See the above "GENERAL NOTES on `detect_coding_XXX ()' functions". |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5428 Check if a text is encoded in a charset-based coding system. If it |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5429 is, return 1, else return 0. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5430 |
88365 | 5431 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
5432 detect_coding_charset (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
5433 struct coding_detection_info *detect_info) |
88365 | 5434 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5435 const unsigned char *src = coding->source, *src_base; |
89483 | 5436 const unsigned char *src_end = coding->source + coding->src_bytes; |
88365 | 5437 int multibytep = coding->src_multibyte; |
5438 int consumed_chars = 0; | |
98951
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5439 Lisp_Object attrs, valids, name; |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
5440 int found = 0; |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5441 int head_ascii = coding->head_ascii; |
98951
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5442 int check_latin_extra = 0; |
88365 | 5443 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5444 detect_info->checked |= CATEGORY_MASK_CHARSET; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5445 |
88365 | 5446 coding = &coding_categories[coding_category_charset]; |
5447 attrs = CODING_ID_ATTRS (coding->id); | |
5448 valids = AREF (attrs, coding_attr_charset_valids); | |
98951
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5449 name = CODING_ID_NAME (coding->id); |
102327
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5450 if (strncmp ((char *) SDATA (SYMBOL_NAME (name)), |
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5451 "iso-8859-", sizeof ("iso-8859-") - 1) == 0 |
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5452 || strncmp ((char *) SDATA (SYMBOL_NAME (name)), |
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5453 "iso-latin-", sizeof ("iso-latin-") - 1) == 0) |
98951
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5454 check_latin_extra = 1; |
102327
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5455 |
88365 | 5456 if (! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5457 src += head_ascii; |
88365 | 5458 |
5459 while (1) | |
5460 { | |
5461 int c; | |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5462 Lisp_Object val; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5463 struct charset *charset; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5464 int dim, idx; |
88365 | 5465 |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5466 src_base = src; |
88365 | 5467 ONE_MORE_BYTE (c); |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5468 if (c < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5469 continue; |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5470 val = AREF (valids, c); |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5471 if (NILP (val)) |
88365 | 5472 break; |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
5473 if (c >= 0x80) |
98951
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5474 { |
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5475 if (c < 0xA0 |
102327
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5476 && check_latin_extra |
a1f0d8fadbb1
(detect_coding_charset): Fix last change for non-latin charsets.
Jason Rumney <jasonr@gnu.org>
parents:
102325
diff
changeset
|
5477 && (!VECTORP (Vlatin_extra_code_table) |
102325
2c693a021d83
(detect_coding_charset): If not checking latin extra,
Jason Rumney <jasonr@gnu.org>
parents:
102320
diff
changeset
|
5478 || NILP (XVECTOR (Vlatin_extra_code_table)->contents[c]))) |
98951
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5479 break; |
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5480 found = CATEGORY_MASK_CHARSET; |
71becd1e9707
(detect_coding_charset): For iso-8859-* coding systems,
Kenichi Handa <handa@m17n.org>
parents:
98186
diff
changeset
|
5481 } |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5482 if (INTEGERP (val)) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5483 { |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5484 charset = CHARSET_FROM_ID (XFASTINT (val)); |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5485 dim = CHARSET_DIMENSION (charset); |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5486 for (idx = 1; idx < dim; idx++) |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
5487 { |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5488 if (src == src_end) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5489 goto too_short; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5490 ONE_MORE_BYTE (c); |
93877
62d97ebb13a9
* coding.c (detect_coding_emacs_mule)
Michael Albinus <michael.albinus@gmx.de>
parents:
93595
diff
changeset
|
5491 if (c < charset->code_space[(dim - 1 - idx) * 2] |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5492 || c > charset->code_space[(dim - 1 - idx) * 2 + 1]) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5493 break; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5494 } |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5495 if (idx < dim) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5496 break; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5497 } |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5498 else |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5499 { |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5500 idx = 1; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5501 for (; CONSP (val); val = XCDR (val)) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5502 { |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5503 charset = CHARSET_FROM_ID (XFASTINT (XCAR (val))); |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5504 dim = CHARSET_DIMENSION (charset); |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5505 while (idx < dim) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5506 { |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5507 if (src == src_end) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5508 goto too_short; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5509 ONE_MORE_BYTE (c); |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5510 if (c < charset->code_space[(dim - 1 - idx) * 4] |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5511 || c > charset->code_space[(dim - 1 - idx) * 4 + 1]) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5512 break; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5513 idx++; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5514 } |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5515 if (idx == dim) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5516 { |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5517 val = Qnil; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5518 break; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5519 } |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
5520 } |
90651
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5521 if (CONSP (val)) |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5522 break; |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5523 } |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5524 } |
23c1467f8640
(detect_coding_charset): Fix detection of multi-byte
Kenichi Handa <handa@m17n.org>
parents:
90599
diff
changeset
|
5525 too_short: |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5526 detect_info->rejected |= CATEGORY_MASK_CHARSET; |
88365 | 5527 return 0; |
5528 | |
5529 no_more_source: | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5530 detect_info->found |= found; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5531 return 1; |
88365 | 5532 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5533 |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5534 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5535 decode_coding_charset (struct coding_system *coding) |
88365 | 5536 { |
89483 | 5537 const unsigned char *src = coding->source + coding->consumed; |
5538 const unsigned char *src_end = coding->source + coding->src_bytes; | |
46548
cb1914307488
(encode_eol, detect_coding, detect_eol):
Ken Raeburn <raeburn@raeburn.org>
parents:
46462
diff
changeset
|
5539 const unsigned char *src_base; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
5540 int *charbuf = coding->charbuf + coding->charbuf_used; |
110983 | 5541 /* We may produce one charset annotation in one loop and one more at |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
5542 the end. */ |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
5543 int *charbuf_end |
103035
6e443d717c7b
(decode_coding_utf_16): Reduce charbuf_end for the
Kenichi Handa <handa@m17n.org>
parents:
102738
diff
changeset
|
5544 = coding->charbuf + coding->charbuf_size - (MAX_ANNOTATION_LENGTH * 2); |
88365 | 5545 int consumed_chars = 0, consumed_chars_base; |
5546 int multibytep = coding->src_multibyte; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5547 Lisp_Object attrs, charset_list, valids; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5548 int char_offset = coding->produced_char; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5549 int last_offset = char_offset; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5550 int last_id = charset_ascii; |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
5551 int eol_crlf = |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
5552 !inhibit_eol_conversion && EQ (CODING_ID_EOL_TYPE (coding->id), Qdos); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5553 int byte_after_cr = -1; |
88365 | 5554 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5555 CODING_GET_INFO (coding, attrs, charset_list); |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5556 valids = AREF (attrs, coding_attr_charset_valids); |
88365 | 5557 |
5558 while (1) | |
5559 { | |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5560 int c; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5561 Lisp_Object val; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5562 struct charset *charset; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5563 int dim; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5564 int len = 1; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5565 unsigned code; |
88365 | 5566 |
29093
176708661b08
(encode_eol): Fix a bug of DOS style EOL encoding.
Kenichi Handa <handa@m17n.org>
parents:
29005
diff
changeset
|
5567 src_base = src; |
88365 | 5568 consumed_chars_base = consumed_chars; |
5569 | |
5570 if (charbuf >= charbuf_end) | |
100936
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
5571 { |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
5572 if (byte_after_cr >= 0) |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
5573 src_base--; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
5574 break; |
5c5e6d041634
(decode_coding_utf_8): Check byte_after_cr before breaking the loop.
Kenichi Handa <handa@m17n.org>
parents:
100587
diff
changeset
|
5575 } |
88365 | 5576 |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5577 if (byte_after_cr >= 0) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5578 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5579 c = byte_after_cr; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5580 byte_after_cr = -1; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5581 } |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5582 else |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5583 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5584 ONE_MORE_BYTE (c); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5585 if (eol_crlf && c == '\r') |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5586 ONE_MORE_BYTE (byte_after_cr); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
5587 } |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5588 if (c < 0) |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5589 goto invalid_code; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5590 code = c; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5591 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5592 val = AREF (valids, c); |
100170
86455974b971
(decode_coding_charset): Check type of an element of
Kenichi Handa <handa@m17n.org>
parents:
100135
diff
changeset
|
5593 if (! INTEGERP (val) && ! CONSP (val)) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5594 goto invalid_code; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5595 if (INTEGERP (val)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5596 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5597 charset = CHARSET_FROM_ID (XFASTINT (val)); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5598 dim = CHARSET_DIMENSION (charset); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5599 while (len < dim) |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5600 { |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
5601 ONE_MORE_BYTE (c); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5602 code = (code << 8) | c; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5603 len++; |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
5604 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5605 CODING_DECODE_CHAR (coding, src, src_base, src_end, |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5606 charset, code, c); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5607 } |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
5608 else |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5609 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5610 /* VAL is a list of charset IDs. It is assured that the |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5611 list is sorted by charset dimensions (smaller one |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5612 comes first). */ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5613 while (CONSP (val)) |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5614 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5615 charset = CHARSET_FROM_ID (XFASTINT (XCAR (val))); |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
5616 dim = CHARSET_DIMENSION (charset); |
88607
18436bf3d6dd
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
88598
diff
changeset
|
5617 while (len < dim) |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5618 { |
88598
b88195f69856
(decode_coding_charset): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
88597
diff
changeset
|
5619 ONE_MORE_BYTE (c); |
b88195f69856
(decode_coding_charset): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
88597
diff
changeset
|
5620 code = (code << 8) | c; |
88607
18436bf3d6dd
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
88598
diff
changeset
|
5621 len++; |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5622 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5623 CODING_DECODE_CHAR (coding, src, src_base, |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5624 src_end, charset, code, c); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5625 if (c >= 0) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5626 break; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5627 val = XCDR (val); |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5628 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5629 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5630 if (c < 0) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5631 goto invalid_code; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5632 if (charset->id != charset_ascii |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5633 && last_id != charset->id) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5634 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5635 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
5636 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5637 last_id = charset->id; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5638 last_offset = char_offset; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5639 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5640 |
88365 | 5641 *charbuf++ = c; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5642 char_offset++; |
88365 | 5643 continue; |
5644 | |
5645 invalid_code: | |
5646 src = src_base; | |
5647 consumed_chars = consumed_chars_base; | |
5648 ONE_MORE_BYTE (c); | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5649 *charbuf++ = c < 0 ? -c : ASCII_BYTE_P (c) ? c : BYTE8_TO_CHAR (c); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5650 char_offset++; |
88365 | 5651 coding->errors++; |
5652 } | |
5653 | |
5654 no_more_source: | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5655 if (last_id != charset_ascii) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
5656 ADD_CHARSET_DATA (charbuf, char_offset - last_offset, last_id); |
88365 | 5657 coding->consumed_char += consumed_chars_base; |
5658 coding->consumed = src_base - coding->source; | |
5659 coding->charbuf_used = charbuf - coding->charbuf; | |
5660 } | |
5661 | |
5662 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5663 encode_coding_charset (struct coding_system *coding) |
88365 | 5664 { |
5665 int multibytep = coding->dst_multibyte; | |
5666 int *charbuf = coding->charbuf; | |
5667 int *charbuf_end = charbuf + coding->charbuf_used; | |
5668 unsigned char *dst = coding->destination + coding->produced; | |
5669 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
5670 int safe_room = MAX_MULTIBYTE_LENGTH; | |
5671 int produced_chars = 0; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5672 Lisp_Object attrs, charset_list; |
88365 | 5673 int ascii_compatible; |
5674 int c; | |
5675 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
5676 CODING_GET_INFO (coding, attrs, charset_list); |
88365 | 5677 ascii_compatible = ! NILP (CODING_ATTR_ASCII_COMPAT (attrs)); |
5678 | |
5679 while (charbuf < charbuf_end) | |
5680 { | |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5681 struct charset *charset; |
88365 | 5682 unsigned code; |
89483 | 5683 |
88365 | 5684 ASSURE_DESTINATION (safe_room); |
5685 c = *charbuf++; | |
5686 if (ascii_compatible && ASCII_CHAR_P (c)) | |
5687 EMIT_ONE_ASCII_BYTE (c); | |
88690
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5688 else if (CHAR_BYTE8_P (c)) |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5689 { |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5690 c = CHAR_TO_BYTE8 (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5691 EMIT_ONE_BYTE (c); |
7f284ac55b07
(encode_coding_emacs_mule): Pay attention to raw-8-bit chars.
Kenichi Handa <handa@m17n.org>
parents:
88681
diff
changeset
|
5692 } |
88365 | 5693 else |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5694 { |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5695 charset = char_charset (c, charset_list, &code); |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5696 if (charset) |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5697 { |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5698 if (CHARSET_DIMENSION (charset) == 1) |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5699 EMIT_ONE_BYTE (code); |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5700 else if (CHARSET_DIMENSION (charset) == 2) |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5701 EMIT_TWO_BYTES (code >> 8, code & 0xFF); |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5702 else if (CHARSET_DIMENSION (charset) == 3) |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5703 EMIT_THREE_BYTES (code >> 16, (code >> 8) & 0xFF, code & 0xFF); |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5704 else |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5705 EMIT_FOUR_BYTES (code >> 24, (code >> 16) & 0xFF, |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5706 (code >> 8) & 0xFF, code & 0xFF); |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5707 } |
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5708 else |
88573
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5709 { |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5710 if (coding->mode & CODING_MODE_SAFE_ENCODING) |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5711 c = CODING_INHIBIT_CHARACTER_SUBSTITUTION; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5712 else |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5713 c = coding->default_char; |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5714 EMIT_ONE_BYTE (c); |
133bf7ab1bad
(encode_coding_iso_2022): If coding requires safe
Kenichi Handa <handa@m17n.org>
parents:
88544
diff
changeset
|
5715 } |
88465
ae455bb40718
(decode_coding_charset, encode_coding_charset): Handle
Kenichi Handa <handa@m17n.org>
parents:
88456
diff
changeset
|
5716 } |
88365 | 5717 } |
5718 | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
5719 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 5720 coding->produced_char += produced_chars; |
5721 coding->produced = dst - coding->destination; | |
5722 return 0; | |
17052 | 5723 } |
5724 | |
5725 | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
5726 /*** 7. C library functions ***/ |
17052 | 5727 |
88365 | 5728 /* Setup coding context CODING from information about CODING_SYSTEM. |
5729 If CODING_SYSTEM is nil, `no-conversion' is assumed. If | |
5730 CODING_SYSTEM is invalid, signal an error. */ | |
5731 | |
5732 void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5733 setup_coding_system (Lisp_Object coding_system, struct coding_system *coding) |
17052 | 5734 { |
88365 | 5735 Lisp_Object attrs; |
5736 Lisp_Object eol_type; | |
5737 Lisp_Object coding_type; | |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
5738 Lisp_Object val; |
17052 | 5739 |
24460
be35d27a4bfb
(setup_coding_system): Check for CODING_SYSTEM = nil.
Kenichi Handa <handa@m17n.org>
parents:
24425
diff
changeset
|
5740 if (NILP (coding_system)) |
90011
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
5741 coding_system = Qundecided; |
88365 | 5742 |
5743 CHECK_CODING_SYSTEM_GET_ID (coding_system, coding->id); | |
5744 | |
5745 attrs = CODING_ID_ATTRS (coding->id); | |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
5746 eol_type = inhibit_eol_conversion ? Qunix : CODING_ID_EOL_TYPE (coding->id); |
88365 | 5747 |
5748 coding->mode = 0; | |
5749 coding->head_ascii = -1; | |
17052 | 5750 if (VECTORP (eol_type)) |
90587
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5751 coding->common_flags = (CODING_REQUIRE_DECODING_MASK |
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5752 | CODING_REQUIRE_DETECTION_MASK); |
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5753 else if (! EQ (eol_type, Qunix)) |
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5754 coding->common_flags = (CODING_REQUIRE_DECODING_MASK |
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5755 | CODING_REQUIRE_ENCODING_MASK); |
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5756 else |
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
5757 coding->common_flags = 0; |
89448
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
5758 if (! NILP (CODING_ATTR_POST_READ (attrs))) |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
5759 coding->common_flags |= CODING_REQUIRE_DECODING_MASK; |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
5760 if (! NILP (CODING_ATTR_PRE_WRITE (attrs))) |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
5761 coding->common_flags |= CODING_REQUIRE_ENCODING_MASK; |
89483 | 5762 if (! NILP (CODING_ATTR_FOR_UNIBYTE (attrs))) |
5763 coding->common_flags |= CODING_FOR_UNIBYTE_MASK; | |
88365 | 5764 |
5765 val = CODING_ATTR_SAFE_CHARSETS (attrs); | |
89483 | 5766 coding->max_charset_id = SCHARS (val) - 1; |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
5767 coding->safe_charsets = SDATA (val); |
88365 | 5768 coding->default_char = XINT (CODING_ATTR_DEFAULT_CHAR (attrs)); |
103655
e2d67c929da2
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
103486
diff
changeset
|
5769 coding->carryover_bytes = 0; |
88365 | 5770 |
5771 coding_type = CODING_ATTR_TYPE (attrs); | |
5772 if (EQ (coding_type, Qundecided)) | |
5773 { | |
5774 coding->detector = NULL; | |
5775 coding->decoder = decode_coding_raw_text; | |
5776 coding->encoder = encode_coding_raw_text; | |
5777 coding->common_flags |= CODING_REQUIRE_DETECTION_MASK; | |
5778 } | |
5779 else if (EQ (coding_type, Qiso_2022)) | |
5780 { | |
5781 int i; | |
5782 int flags = XINT (AREF (attrs, coding_attr_iso_flags)); | |
5783 | |
5784 /* Invoke graphic register 0 to plane 0. */ | |
5785 CODING_ISO_INVOCATION (coding, 0) = 0; | |
5786 /* Invoke graphic register 1 to plane 1 if we can use 8-bit. */ | |
5787 CODING_ISO_INVOCATION (coding, 1) | |
5788 = (flags & CODING_ISO_FLAG_SEVEN_BITS ? -1 : 1); | |
5789 /* Setup the initial status of designation. */ | |
5790 for (i = 0; i < 4; i++) | |
5791 CODING_ISO_DESIGNATION (coding, i) = CODING_ISO_INITIAL (coding, i); | |
5792 /* Not single shifting initially. */ | |
5793 CODING_ISO_SINGLE_SHIFTING (coding) = 0; | |
5794 /* Beginning of buffer should also be regarded as bol. */ | |
5795 CODING_ISO_BOL (coding) = 1; | |
5796 coding->detector = detect_coding_iso_2022; | |
5797 coding->decoder = decode_coding_iso_2022; | |
5798 coding->encoder = encode_coding_iso_2022; | |
5799 if (flags & CODING_ISO_FLAG_SAFE) | |
5800 coding->mode |= CODING_MODE_SAFE_ENCODING; | |
20227
71008f909642
(setup_coding_system): Initialize common_flags member
Kenichi Handa <handa@m17n.org>
parents:
20150
diff
changeset
|
5801 coding->common_flags |
88365 | 5802 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK |
5803 | CODING_REQUIRE_FLUSHING_MASK); | |
5804 if (flags & CODING_ISO_FLAG_COMPOSITION) | |
5805 coding->common_flags |= CODING_ANNOTATE_COMPOSITION_MASK; | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5806 if (flags & CODING_ISO_FLAG_DESIGNATION) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
5807 coding->common_flags |= CODING_ANNOTATE_CHARSET_MASK; |
88365 | 5808 if (flags & CODING_ISO_FLAG_FULL_SUPPORT) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5809 { |
88365 | 5810 setup_iso_safe_charsets (attrs); |
5811 val = CODING_ATTR_SAFE_CHARSETS (attrs); | |
89483 | 5812 coding->max_charset_id = SCHARS (val) - 1; |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
5813 coding->safe_charsets = SDATA (val); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5814 } |
88365 | 5815 CODING_ISO_FLAGS (coding) = flags; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5816 CODING_ISO_CMP_STATUS (coding)->state = COMPOSING_NO; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5817 CODING_ISO_CMP_STATUS (coding)->method = COMPOSITION_NO; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5818 CODING_ISO_EXTSEGMENT_LEN (coding) = 0; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5819 CODING_ISO_EMBEDDED_UTF_8 (coding) = 0; |
88365 | 5820 } |
5821 else if (EQ (coding_type, Qcharset)) | |
5822 { | |
5823 coding->detector = detect_coding_charset; | |
5824 coding->decoder = decode_coding_charset; | |
5825 coding->encoder = encode_coding_charset; | |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
5826 coding->common_flags |
88365 | 5827 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK); |
5828 } | |
5829 else if (EQ (coding_type, Qutf_8)) | |
5830 { | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5831 val = AREF (attrs, coding_attr_utf_bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5832 CODING_UTF_8_BOM (coding) = (CONSP (val) ? utf_detect_bom |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5833 : EQ (val, Qt) ? utf_with_bom |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5834 : utf_without_bom); |
88365 | 5835 coding->detector = detect_coding_utf_8; |
5836 coding->decoder = decode_coding_utf_8; | |
5837 coding->encoder = encode_coding_utf_8; | |
34888
b469d29c0815
(SAFE_ONE_MORE_BYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34813
diff
changeset
|
5838 coding->common_flags |
88365 | 5839 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5840 if (CODING_UTF_8_BOM (coding) == utf_detect_bom) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5841 coding->common_flags |= CODING_REQUIRE_DETECTION_MASK; |
88365 | 5842 } |
5843 else if (EQ (coding_type, Qutf_16)) | |
5844 { | |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5845 val = AREF (attrs, coding_attr_utf_bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5846 CODING_UTF_16_BOM (coding) = (CONSP (val) ? utf_detect_bom |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5847 : EQ (val, Qt) ? utf_with_bom |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5848 : utf_without_bom); |
88365 | 5849 val = AREF (attrs, coding_attr_utf_16_endian); |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
5850 CODING_UTF_16_ENDIAN (coding) = (EQ (val, Qbig) ? utf_16_big_endian |
88365 | 5851 : utf_16_little_endian); |
88438
3a34b722dd71
(encode_coding_utf_8): Initialize produced_chars to 0.
Kenichi Handa <handa@m17n.org>
parents:
88430
diff
changeset
|
5852 CODING_UTF_16_SURROGATE (coding) = 0; |
88365 | 5853 coding->detector = detect_coding_utf_16; |
5854 coding->decoder = decode_coding_utf_16; | |
5855 coding->encoder = encode_coding_utf_16; | |
20227
71008f909642
(setup_coding_system): Initialize common_flags member
Kenichi Handa <handa@m17n.org>
parents:
20150
diff
changeset
|
5856 coding->common_flags |
88365 | 5857 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
5858 if (CODING_UTF_16_BOM (coding) == utf_detect_bom) |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
5859 coding->common_flags |= CODING_REQUIRE_DETECTION_MASK; |
88365 | 5860 } |
5861 else if (EQ (coding_type, Qccl)) | |
5862 { | |
5863 coding->detector = detect_coding_ccl; | |
5864 coding->decoder = decode_coding_ccl; | |
5865 coding->encoder = encode_coding_ccl; | |
20227
71008f909642
(setup_coding_system): Initialize common_flags member
Kenichi Handa <handa@m17n.org>
parents:
20150
diff
changeset
|
5866 coding->common_flags |
88365 | 5867 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK |
5868 | CODING_REQUIRE_FLUSHING_MASK); | |
5869 } | |
5870 else if (EQ (coding_type, Qemacs_mule)) | |
5871 { | |
5872 coding->detector = detect_coding_emacs_mule; | |
5873 coding->decoder = decode_coding_emacs_mule; | |
5874 coding->encoder = encode_coding_emacs_mule; | |
20227
71008f909642
(setup_coding_system): Initialize common_flags member
Kenichi Handa <handa@m17n.org>
parents:
20150
diff
changeset
|
5875 coding->common_flags |
88365 | 5876 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5877 coding->spec.emacs_mule.full_support = 1; |
88365 | 5878 if (! NILP (AREF (attrs, coding_attr_emacs_mule_full)) |
5879 && ! EQ (CODING_ATTR_CHARSET_LIST (attrs), Vemacs_mule_charset_list)) | |
5880 { | |
5881 Lisp_Object tail, safe_charsets; | |
5882 int max_charset_id = 0; | |
5883 | |
5884 for (tail = Vemacs_mule_charset_list; CONSP (tail); | |
5885 tail = XCDR (tail)) | |
5886 if (max_charset_id < XFASTINT (XCAR (tail))) | |
5887 max_charset_id = XFASTINT (XCAR (tail)); | |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
5888 safe_charsets = make_uninit_string (max_charset_id + 1); |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
5889 memset (SDATA (safe_charsets), 255, max_charset_id + 1); |
88365 | 5890 for (tail = Vemacs_mule_charset_list; CONSP (tail); |
5891 tail = XCDR (tail)) | |
89483 | 5892 SSET (safe_charsets, XFASTINT (XCAR (tail)), 0); |
88365 | 5893 coding->max_charset_id = max_charset_id; |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
5894 coding->safe_charsets = SDATA (safe_charsets); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5895 coding->spec.emacs_mule.full_support = 1; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5896 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5897 coding->spec.emacs_mule.cmp_status.state = COMPOSING_NO; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
5898 coding->spec.emacs_mule.cmp_status.method = COMPOSITION_NO; |
88365 | 5899 } |
5900 else if (EQ (coding_type, Qshift_jis)) | |
5901 { | |
5902 coding->detector = detect_coding_sjis; | |
5903 coding->decoder = decode_coding_sjis; | |
5904 coding->encoder = encode_coding_sjis; | |
5905 coding->common_flags | |
5906 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK); | |
5907 } | |
5908 else if (EQ (coding_type, Qbig5)) | |
5909 { | |
5910 coding->detector = detect_coding_big5; | |
5911 coding->decoder = decode_coding_big5; | |
5912 coding->encoder = encode_coding_big5; | |
20227
71008f909642
(setup_coding_system): Initialize common_flags member
Kenichi Handa <handa@m17n.org>
parents:
20150
diff
changeset
|
5913 coding->common_flags |
88365 | 5914 |= (CODING_REQUIRE_DECODING_MASK | CODING_REQUIRE_ENCODING_MASK); |
5915 } | |
5916 else /* EQ (coding_type, Qraw_text) */ | |
5917 { | |
5918 coding->detector = NULL; | |
5919 coding->decoder = decode_coding_raw_text; | |
5920 coding->encoder = encode_coding_raw_text; | |
89933
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5921 if (! EQ (eol_type, Qunix)) |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5922 { |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5923 coding->common_flags |= CODING_REQUIRE_DECODING_MASK; |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5924 if (! VECTORP (eol_type)) |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5925 coding->common_flags |= CODING_REQUIRE_ENCODING_MASK; |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5926 } |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
5927 |
88365 | 5928 } |
5929 | |
22616
c493ce6a31e4
(setup_raw_text_coding_system): New function.
Kenichi Handa <handa@m17n.org>
parents:
22529
diff
changeset
|
5930 return; |
c493ce6a31e4
(setup_raw_text_coding_system): New function.
Kenichi Handa <handa@m17n.org>
parents:
22529
diff
changeset
|
5931 } |
c493ce6a31e4
(setup_raw_text_coding_system): New function.
Kenichi Handa <handa@m17n.org>
parents:
22529
diff
changeset
|
5932 |
90061
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5933 /* Return a list of charsets supported by CODING. */ |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5934 |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5935 Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5936 coding_charset_list (struct coding_system *coding) |
26847 | 5937 { |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
5938 Lisp_Object attrs, charset_list; |
90061
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5939 |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5940 CODING_GET_INFO (coding, attrs, charset_list); |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5941 if (EQ (CODING_ATTR_TYPE (attrs), Qiso_2022)) |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5942 { |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5943 int flags = XINT (AREF (attrs, coding_attr_iso_flags)); |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5944 |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5945 if (flags & CODING_ISO_FLAG_FULL_SUPPORT) |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5946 charset_list = Viso_2022_charset_list; |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5947 } |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5948 else if (EQ (CODING_ATTR_TYPE (attrs), Qemacs_mule)) |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5949 { |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5950 charset_list = Vemacs_mule_charset_list; |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5951 } |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5952 return charset_list; |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5953 } |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5954 |
48210be97b12
Cancel the change done in HEAD on 2004-11-30.
Kenichi Handa <handa@m17n.org>
parents:
90054
diff
changeset
|
5955 |
101776
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5956 /* Return a list of charsets supported by CODING-SYSTEM. */ |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5957 |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5958 Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5959 coding_system_charset_list (Lisp_Object coding_system) |
101776
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5960 { |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5961 int id; |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5962 Lisp_Object attrs, charset_list; |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5963 |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5964 CHECK_CODING_SYSTEM_GET_ID (coding_system, id); |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5965 attrs = CODING_ID_ATTRS (id); |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5966 |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5967 if (EQ (CODING_ATTR_TYPE (attrs), Qiso_2022)) |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5968 { |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5969 int flags = XINT (AREF (attrs, coding_attr_iso_flags)); |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5970 |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5971 if (flags & CODING_ISO_FLAG_FULL_SUPPORT) |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5972 charset_list = Viso_2022_charset_list; |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5973 else |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5974 charset_list = CODING_ATTR_CHARSET_LIST (attrs); |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5975 } |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5976 else if (EQ (CODING_ATTR_TYPE (attrs), Qemacs_mule)) |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5977 { |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5978 charset_list = Vemacs_mule_charset_list; |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5979 } |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5980 else |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5981 { |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5982 charset_list = CODING_ATTR_CHARSET_LIST (attrs); |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5983 } |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5984 return charset_list; |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5985 } |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5986 |
11ba351ce12b
(coding_system_charset_list): New function.
Kenichi Handa <handa@m17n.org>
parents:
101678
diff
changeset
|
5987 |
88365 | 5988 /* Return raw-text or one of its subsidiaries that has the same |
5989 eol_type as CODING-SYSTEM. */ | |
5990 | |
5991 Lisp_Object | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
5992 raw_text_coding_system (Lisp_Object coding_system) |
26847 | 5993 { |
88430
6418a272b97e
* coding.c: Delete unused variables.
Kenichi Handa <handa@m17n.org>
parents:
88365
diff
changeset
|
5994 Lisp_Object spec, attrs; |
88365 | 5995 Lisp_Object eol_type, raw_text_eol_type; |
5996 | |
89462
4e359ebf3984
(decode_coding_iso_2022): Fix handling of invalid
Kenichi Handa <handa@m17n.org>
parents:
89448
diff
changeset
|
5997 if (NILP (coding_system)) |
4e359ebf3984
(decode_coding_iso_2022): Fix handling of invalid
Kenichi Handa <handa@m17n.org>
parents:
89448
diff
changeset
|
5998 return Qraw_text; |
88365 | 5999 spec = CODING_SYSTEM_SPEC (coding_system); |
6000 attrs = AREF (spec, 0); | |
89483 | 6001 |
88365 | 6002 if (EQ (CODING_ATTR_TYPE (attrs), Qraw_text)) |
6003 return coding_system; | |
6004 | |
6005 eol_type = AREF (spec, 2); | |
6006 if (VECTORP (eol_type)) | |
6007 return Qraw_text; | |
6008 spec = CODING_SYSTEM_SPEC (Qraw_text); | |
6009 raw_text_eol_type = AREF (spec, 2); | |
6010 return (EQ (eol_type, Qunix) ? AREF (raw_text_eol_type, 0) | |
6011 : EQ (eol_type, Qdos) ? AREF (raw_text_eol_type, 1) | |
6012 : AREF (raw_text_eol_type, 2)); | |
26847 | 6013 } |
6014 | |
88365 | 6015 |
110834
b997f43af473
Fix complementing of a coding system
Kenichi Handa <handa@m17n.org>
parents:
110829
diff
changeset
|
6016 /* If CODING_SYSTEM doesn't specify end-of-line format, return one of |
b997f43af473
Fix complementing of a coding system
Kenichi Handa <handa@m17n.org>
parents:
110829
diff
changeset
|
6017 the subsidiary that has the same eol-spec as PARENT (if it is not |
b997f43af473
Fix complementing of a coding system
Kenichi Handa <handa@m17n.org>
parents:
110829
diff
changeset
|
6018 nil and specifies end-of-line format) or the system's setting |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6019 (system_eol_type). */ |
88365 | 6020 |
6021 Lisp_Object | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6022 coding_inherit_eol_type (Lisp_Object coding_system, Lisp_Object parent) |
22616
c493ce6a31e4
(setup_raw_text_coding_system): New function.
Kenichi Handa <handa@m17n.org>
parents:
22529
diff
changeset
|
6023 { |
89545
4f394eed6ff2
(inhibit_pre_post_conversion): Removed (unused).
Dave Love <fx@gnu.org>
parents:
89519
diff
changeset
|
6024 Lisp_Object spec, eol_type; |
88365 | 6025 |
89462
4e359ebf3984
(decode_coding_iso_2022): Fix handling of invalid
Kenichi Handa <handa@m17n.org>
parents:
89448
diff
changeset
|
6026 if (NILP (coding_system)) |
4e359ebf3984
(decode_coding_iso_2022): Fix handling of invalid
Kenichi Handa <handa@m17n.org>
parents:
89448
diff
changeset
|
6027 coding_system = Qraw_text; |
88365 | 6028 spec = CODING_SYSTEM_SPEC (coding_system); |
6029 eol_type = AREF (spec, 2); | |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6030 if (VECTORP (eol_type)) |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6031 { |
88365 | 6032 Lisp_Object parent_eol_type; |
6033 | |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6034 if (! NILP (parent)) |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6035 { |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6036 Lisp_Object parent_spec; |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6037 |
90587
fe721cfad011
(setup_coding_system): Fix setting of
Kenichi Handa <handa@m17n.org>
parents:
90573
diff
changeset
|
6038 parent_spec = CODING_SYSTEM_SPEC (parent); |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6039 parent_eol_type = AREF (parent_spec, 2); |
110834
b997f43af473
Fix complementing of a coding system
Kenichi Handa <handa@m17n.org>
parents:
110829
diff
changeset
|
6040 if (VECTORP (parent_eol_type)) |
110855
bec49af30c2f
Merge changes from emacs-23 branch.
Juanma Barranquero <lekktu@gmail.com>
diff
changeset
|
6041 parent_eol_type = system_eol_type; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6042 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6043 else |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
6044 parent_eol_type = system_eol_type; |
88365 | 6045 if (EQ (parent_eol_type, Qunix)) |
6046 coding_system = AREF (eol_type, 0); | |
6047 else if (EQ (parent_eol_type, Qdos)) | |
6048 coding_system = AREF (eol_type, 1); | |
6049 else if (EQ (parent_eol_type, Qmac)) | |
6050 coding_system = AREF (eol_type, 2); | |
6051 } | |
6052 return coding_system; | |
22616
c493ce6a31e4
(setup_raw_text_coding_system): New function.
Kenichi Handa <handa@m17n.org>
parents:
22529
diff
changeset
|
6053 } |
c493ce6a31e4
(setup_raw_text_coding_system): New function.
Kenichi Handa <handa@m17n.org>
parents:
22529
diff
changeset
|
6054 |
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6055 |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6056 /* Check if text-conversion and eol-conversion of CODING_SYSTEM are |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6057 decided for writing to a process. If not, complement them, and |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6058 return a new coding system. */ |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6059 |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6060 Lisp_Object |
110855
bec49af30c2f
Merge changes from emacs-23 branch.
Juanma Barranquero <lekktu@gmail.com>
diff
changeset
|
6061 complement_process_encoding_system (Lisp_Object coding_system) |
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6062 { |
110845
394a9ff3e3cf
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110834
diff
changeset
|
6063 Lisp_Object coding_base = Qnil, eol_base = Qnil; |
394a9ff3e3cf
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110834
diff
changeset
|
6064 Lisp_Object spec, attrs; |
110847
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6065 int i; |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6066 |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6067 for (i = 0; i < 3; i++) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6068 { |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6069 if (i == 1) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6070 coding_system = CDR_SAFE (Vdefault_process_coding_system); |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6071 else if (i == 2) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6072 coding_system = preferred_coding_system (); |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6073 spec = CODING_SYSTEM_SPEC (coding_system); |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6074 if (NILP (spec)) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6075 continue; |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6076 attrs = AREF (spec, 0); |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6077 if (NILP (coding_base) && ! EQ (CODING_ATTR_TYPE (attrs), Qundecided)) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6078 coding_base = CODING_ATTR_BASE_NAME (attrs); |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6079 if (NILP (eol_base) && ! VECTORP (AREF (spec, 2))) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6080 eol_base = coding_system; |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6081 if (! NILP (coding_base) && ! NILP (eol_base)) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6082 break; |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6083 } |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6084 |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6085 if (i > 0) |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6086 /* The original CODING_SYSTEM didn't specify text-conversion or |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6087 eol-conversion. Be sure that we return a fully complemented |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6088 coding system. */ |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6089 coding_system = coding_inherit_eol_type (coding_base, eol_base); |
c234b2db847c
coding.c (complement_process_encoding_system): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
110845
diff
changeset
|
6090 return coding_system; |
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6091 } |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6092 |
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
110336
diff
changeset
|
6093 |
17052 | 6094 /* Emacs has a mechanism to automatically detect a coding system if it |
6095 is one of Emacs' internal format, ISO2022, SJIS, and BIG5. But, | |
6096 it's impossible to distinguish some coding systems accurately | |
6097 because they use the same range of codes. So, at first, coding | |
6098 systems are categorized into 7, those are: | |
6099 | |
17835
f36ffb6f1208
Name change through the code:
Kenichi Handa <handa@m17n.org>
parents:
17725
diff
changeset
|
6100 o coding-category-emacs-mule |
17052 | 6101 |
6102 The category for a coding system which has the same code range | |
6103 as Emacs' internal format. Assigned the coding-system (Lisp | |
17835
f36ffb6f1208
Name change through the code:
Kenichi Handa <handa@m17n.org>
parents:
17725
diff
changeset
|
6104 symbol) `emacs-mule' by default. |
17052 | 6105 |
6106 o coding-category-sjis | |
6107 | |
6108 The category for a coding system which has the same code range | |
6109 as SJIS. Assigned the coding-system (Lisp | |
18787
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6110 symbol) `japanese-shift-jis' by default. |
17052 | 6111 |
6112 o coding-category-iso-7 | |
6113 | |
6114 The category for a coding system which has the same code range | |
18787
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6115 as ISO2022 of 7-bit environment. This doesn't use any locking |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6116 shift and single shift functions. This can encode/decode all |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6117 charsets. Assigned the coding-system (Lisp symbol) |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6118 `iso-2022-7bit' by default. |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6119 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6120 o coding-category-iso-7-tight |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6121 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6122 Same as coding-category-iso-7 except that this can |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6123 encode/decode only the specified charsets. |
17052 | 6124 |
6125 o coding-category-iso-8-1 | |
6126 | |
6127 The category for a coding system which has the same code range | |
6128 as ISO2022 of 8-bit environment and graphic plane 1 used only | |
18787
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6129 for DIMENSION1 charset. This doesn't use any locking shift |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6130 and single shift functions. Assigned the coding-system (Lisp |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6131 symbol) `iso-latin-1' by default. |
17052 | 6132 |
6133 o coding-category-iso-8-2 | |
6134 | |
6135 The category for a coding system which has the same code range | |
6136 as ISO2022 of 8-bit environment and graphic plane 1 used only | |
18787
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6137 for DIMENSION2 charset. This doesn't use any locking shift |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6138 and single shift functions. Assigned the coding-system (Lisp |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6139 symbol) `japanese-iso-8bit' by default. |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6140 |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6141 o coding-category-iso-7-else |
17052 | 6142 |
6143 The category for a coding system which has the same code range | |
110983 | 6144 as ISO2022 of 7-bit environment but uses locking shift or |
18787
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6145 single shift functions. Assigned the coding-system (Lisp |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6146 symbol) `iso-2022-7bit-lock' by default. |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6147 |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6148 o coding-category-iso-8-else |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6149 |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6150 The category for a coding system which has the same code range |
110983 | 6151 as ISO2022 of 8-bit environment but uses locking shift or |
18787
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6152 single shift functions. Assigned the coding-system (Lisp |
954e6be0a757
(detect_coding_iso2022): Distinguish coding-category-iso-7-else and
Kenichi Handa <handa@m17n.org>
parents:
18766
diff
changeset
|
6153 symbol) `iso-2022-8bit-ss2' by default. |
17052 | 6154 |
6155 o coding-category-big5 | |
6156 | |
6157 The category for a coding system which has the same code range | |
6158 as BIG5. Assigned the coding-system (Lisp symbol) | |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
6159 `cn-big5' by default. |
17052 | 6160 |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6161 o coding-category-utf-8 |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6162 |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6163 The category for a coding system which has the same code range |
54303 | 6164 as UTF-8 (cf. RFC3629). Assigned the coding-system (Lisp |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6165 symbol) `utf-8' by default. |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6166 |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6167 o coding-category-utf-16-be |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6168 |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6169 The category for a coding system in which a text has an |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6170 Unicode signature (cf. Unicode Standard) in the order of BIG |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6171 endian at the head. Assigned the coding-system (Lisp symbol) |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6172 `utf-16-be' by default. |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6173 |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6174 o coding-category-utf-16-le |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6175 |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6176 The category for a coding system in which a text has an |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6177 Unicode signature (cf. Unicode Standard) in the order of |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6178 LITTLE endian at the head. Assigned the coding-system (Lisp |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6179 symbol) `utf-16-le' by default. |
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6180 |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
6181 o coding-category-ccl |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
6182 |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
6183 The category for a coding system of which encoder/decoder is |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
6184 written in CCL programs. The default value is nil, i.e., no |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
6185 coding system is assigned. |
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
6186 |
17052 | 6187 o coding-category-binary |
6188 | |
6189 The category for a coding system not categorized in any of the | |
6190 above. Assigned the coding-system (Lisp symbol) | |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
6191 `no-conversion' by default. |
17052 | 6192 |
6193 Each of them is a Lisp symbol and the value is an actual | |
88365 | 6194 `coding-system's (this is also a Lisp symbol) assigned by a user. |
17052 | 6195 What Emacs does actually is to detect a category of coding system. |
6196 Then, it uses a `coding-system' assigned to it. If Emacs can't | |
88365 | 6197 decide only one possible category, it selects a category of the |
17052 | 6198 highest priority. Priorities of categories are also specified by a |
6199 user in a Lisp variable `coding-category-list'. | |
6200 | |
6201 */ | |
6202 | |
88365 | 6203 #define EOL_SEEN_NONE 0 |
6204 #define EOL_SEEN_LF 1 | |
6205 #define EOL_SEEN_CR 2 | |
6206 #define EOL_SEEN_CRLF 4 | |
17052 | 6207 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6208 /* Detect how end-of-line of a text of length SRC_BYTES pointed by |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6209 SOURCE is encoded. If CATEGORY is one of |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6210 coding_category_utf_16_XXXX, assume that CR and LF are encoded by |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6211 two-byte, else they are encoded by one-byte. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6212 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6213 Return one of EOL_SEEN_XXX. */ |
17052 | 6214 |
19173
04ed7c3f5cee
(detect_eol_type): If EOL representation does not
Richard M. Stallman <rms@gnu.org>
parents:
19134
diff
changeset
|
6215 #define MAX_EOL_CHECK_COUNT 3 |
04ed7c3f5cee
(detect_eol_type): If EOL representation does not
Richard M. Stallman <rms@gnu.org>
parents:
19134
diff
changeset
|
6216 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6217 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
6218 detect_eol (const unsigned char *source, EMACS_INT src_bytes, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
6219 enum coding_category category) |
17052 | 6220 { |
84646
922a7e3b7383
(detect_eol_type, detect_eol_type_in_2_octet_form):
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents:
83648
diff
changeset
|
6221 const unsigned char *src = source, *src_end = src + src_bytes; |
17052 | 6222 unsigned char c; |
88365 | 6223 int total = 0; |
6224 int eol_seen = EOL_SEEN_NONE; | |
6225 | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
6226 if ((1 << category) & CATEGORY_MASK_UTF_16) |
88365 | 6227 { |
6228 int msb, lsb; | |
6229 | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
6230 msb = category == (coding_category_utf_16_le |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
6231 | coding_category_utf_16_le_nosig); |
88365 | 6232 lsb = 1 - msb; |
6233 | |
6234 while (src + 1 < src_end) | |
17052 | 6235 { |
88365 | 6236 c = src[lsb]; |
6237 if (src[msb] == 0 && (c == '\n' || c == '\r')) | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6238 { |
88365 | 6239 int this_eol; |
6240 | |
6241 if (c == '\n') | |
6242 this_eol = EOL_SEEN_LF; | |
6243 else if (src + 3 >= src_end | |
6244 || src[msb + 2] != 0 | |
6245 || src[lsb + 2] != '\n') | |
6246 this_eol = EOL_SEEN_CR; | |
6247 else | |
101678
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6248 { |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6249 this_eol = EOL_SEEN_CRLF; |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6250 src += 2; |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6251 } |
88365 | 6252 |
6253 if (eol_seen == EOL_SEEN_NONE) | |
6254 /* This is the first end-of-line. */ | |
6255 eol_seen = this_eol; | |
6256 else if (eol_seen != this_eol) | |
6257 { | |
101678
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6258 /* The found type is different from what found before. |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6259 Allow for stray ^M characters in DOS EOL files. */ |
111997
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6260 if ((eol_seen == EOL_SEEN_CR && this_eol == EOL_SEEN_CRLF) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6261 || (eol_seen == EOL_SEEN_CRLF |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6262 && this_eol == EOL_SEEN_CR)) |
101678
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6263 eol_seen = EOL_SEEN_CRLF; |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6264 else |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6265 { |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6266 eol_seen = EOL_SEEN_LF; |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6267 break; |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6268 } |
88365 | 6269 } |
6270 if (++total == MAX_EOL_CHECK_COUNT) | |
6271 break; | |
6272 } | |
6273 src += 2; | |
6274 } | |
30833
2db6e42a6ba3
(MINIMUM_CONVERSION_BUFFER_SIZE): Macro deleted.
Kenichi Handa <handa@m17n.org>
parents:
30756
diff
changeset
|
6275 } |
88365 | 6276 else |
111997
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6277 while (src < src_end) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6278 { |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6279 c = *src++; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6280 if (c == '\n' || c == '\r') |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6281 { |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6282 int this_eol; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6283 |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6284 if (c == '\n') |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6285 this_eol = EOL_SEEN_LF; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6286 else if (src >= src_end || *src != '\n') |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6287 this_eol = EOL_SEEN_CR; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6288 else |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6289 this_eol = EOL_SEEN_CRLF, src++; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6290 |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6291 if (eol_seen == EOL_SEEN_NONE) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6292 /* This is the first end-of-line. */ |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6293 eol_seen = this_eol; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6294 else if (eol_seen != this_eol) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6295 { |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6296 /* The found type is different from what found before. |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6297 Allow for stray ^M characters in DOS EOL files. */ |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6298 if ((eol_seen == EOL_SEEN_CR && this_eol == EOL_SEEN_CRLF) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6299 || (eol_seen == EOL_SEEN_CRLF && this_eol == EOL_SEEN_CR)) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6300 eol_seen = EOL_SEEN_CRLF; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6301 else |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6302 { |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6303 eol_seen = EOL_SEEN_LF; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6304 break; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6305 } |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6306 } |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6307 if (++total == MAX_EOL_CHECK_COUNT) |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6308 break; |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6309 } |
a5a188ddc758
Minor clean up to silence some gcc warnings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
111779
diff
changeset
|
6310 } |
88365 | 6311 return eol_seen; |
17052 | 6312 } |
6313 | |
88365 | 6314 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6315 static Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6316 adjust_coding_eol_type (struct coding_system *coding, int eol_seen) |
88365 | 6317 { |
88430
6418a272b97e
* coding.c: Delete unused variables.
Kenichi Handa <handa@m17n.org>
parents:
88365
diff
changeset
|
6318 Lisp_Object eol_type; |
89483 | 6319 |
88365 | 6320 eol_type = CODING_ID_EOL_TYPE (coding->id); |
6321 if (eol_seen & EOL_SEEN_LF) | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6322 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6323 coding->id = CODING_SYSTEM_ID (AREF (eol_type, 0)); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6324 eol_type = Qunix; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6325 } |
88862
108e2535280d
(adjust_coding_eol_type): Fix eol_type/eol_seen mixup.
Dave Love <fx@gnu.org>
parents:
88856
diff
changeset
|
6326 else if (eol_seen & EOL_SEEN_CRLF) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6327 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6328 coding->id = CODING_SYSTEM_ID (AREF (eol_type, 1)); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6329 eol_type = Qdos; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6330 } |
88862
108e2535280d
(adjust_coding_eol_type): Fix eol_type/eol_seen mixup.
Dave Love <fx@gnu.org>
parents:
88856
diff
changeset
|
6331 else if (eol_seen & EOL_SEEN_CR) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6332 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6333 coding->id = CODING_SYSTEM_ID (AREF (eol_type, 2)); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6334 eol_type = Qmac; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6335 } |
19181
917138730635
(detect_eol_type): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
19173
diff
changeset
|
6336 return eol_type; |
17052 | 6337 } |
6338 | |
88365 | 6339 /* Detect how a text specified in CODING is encoded. If a coding |
6340 system is detected, update fields of CODING by the detected coding | |
6341 system. */ | |
17052 | 6342 |
6343 void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6344 detect_coding (struct coding_system *coding) |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6345 { |
89483 | 6346 const unsigned char *src, *src_end; |
102105
a5023e8bbb1e
(detect_coding): Preserve coding->mode.
Kenichi Handa <handa@m17n.org>
parents:
102058
diff
changeset
|
6347 int saved_mode = coding->mode; |
88365 | 6348 |
6349 coding->consumed = coding->consumed_char = 0; | |
6350 coding->produced = coding->produced_char = 0; | |
6351 coding_set_source (coding); | |
6352 | |
6353 src_end = coding->source + coding->src_bytes; | |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6354 coding->head_ascii = 0; |
88365 | 6355 |
6356 /* If we have not yet decided the text encoding type, detect it | |
6357 now. */ | |
6358 if (EQ (CODING_ATTR_TYPE (CODING_ID_ATTRS (coding->id)), Qundecided)) | |
6359 { | |
6360 int c, i; | |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6361 struct coding_detection_info detect_info; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6362 int null_byte_found = 0, eight_bit_found = 0; |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6363 |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6364 detect_info.checked = detect_info.found = detect_info.rejected = 0; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6365 for (src = coding->source; src < src_end; src++) |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6366 { |
88365 | 6367 c = *src; |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6368 if (c & 0x80) |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6369 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6370 eight_bit_found = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6371 if (null_byte_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6372 break; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6373 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6374 else if (c < 0x20) |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6375 { |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6376 if ((c == ISO_CODE_ESC || c == ISO_CODE_SI || c == ISO_CODE_SO) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6377 && ! inhibit_iso_escape_detection |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6378 && ! detect_info.checked) |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6379 { |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6380 if (detect_coding_iso_2022 (coding, &detect_info)) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6381 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6382 /* We have scanned the whole data. */ |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6383 if (! (detect_info.rejected & CATEGORY_MASK_ISO_7_ELSE)) |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6384 { |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6385 /* We didn't find an 8-bit code. We may |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6386 have found a null-byte, but it's very |
107984
bef5d1738c0b
Make variable forwarding explicit rather the using special values.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107507
diff
changeset
|
6387 rare that a binary file conforms to |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6388 ISO-2022. */ |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6389 src = src_end; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6390 coding->head_ascii = src - coding->source; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6391 } |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6392 detect_info.rejected |= ~CATEGORY_MASK_ISO_ESCAPE; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6393 break; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6394 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6395 } |
101040 | 6396 else if (! c && !inhibit_null_byte_detection) |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6397 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6398 null_byte_found = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6399 if (eight_bit_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6400 break; |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6401 } |
95585
862c7386145c
(detect_coding): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95533
diff
changeset
|
6402 if (! eight_bit_found) |
862c7386145c
(detect_coding): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95533
diff
changeset
|
6403 coding->head_ascii++; |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6404 } |
95585
862c7386145c
(detect_coding): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95533
diff
changeset
|
6405 else if (! eight_bit_found) |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6406 coding->head_ascii++; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6407 } |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6408 |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6409 if (null_byte_found || eight_bit_found |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6410 || coding->head_ascii < coding->src_bytes |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6411 || detect_info.found) |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6412 { |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6413 enum coding_category category; |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6414 struct coding_system *this; |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6415 |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6416 if (coding->head_ascii == coding->src_bytes) |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6417 /* As all bytes are 7-bit, we can ignore non-ISO-2022 codings. */ |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6418 for (i = 0; i < coding_category_raw_text; i++) |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6419 { |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6420 category = coding_priorities[i]; |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6421 this = coding_categories + category; |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6422 if (detect_info.found & (1 << category)) |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6423 break; |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6424 } |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6425 else |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6426 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6427 if (null_byte_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6428 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6429 detect_info.checked |= ~CATEGORY_MASK_UTF_16; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6430 detect_info.rejected |= ~CATEGORY_MASK_UTF_16; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6431 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6432 for (i = 0; i < coding_category_raw_text; i++) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6433 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6434 category = coding_priorities[i]; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6435 this = coding_categories + category; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6436 if (this->id < 0) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6437 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6438 /* No coding system of this category is defined. */ |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6439 detect_info.rejected |= (1 << category); |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6440 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6441 else if (category >= coding_category_raw_text) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6442 continue; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6443 else if (detect_info.checked & (1 << category)) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6444 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6445 if (detect_info.found & (1 << category)) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6446 break; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6447 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6448 else if ((*(this->detector)) (coding, &detect_info) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6449 && detect_info.found & (1 << category)) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6450 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6451 if (category == coding_category_utf_16_auto) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6452 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6453 if (detect_info.found & CATEGORY_MASK_UTF_16_LE) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6454 category = coding_category_utf_16_le; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6455 else |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6456 category = coding_category_utf_16_be; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6457 } |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
6458 break; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6459 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6460 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
6461 } |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6462 |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6463 if (i < coding_category_raw_text) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6464 setup_coding_system (CODING_ID_NAME (this->id), coding); |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6465 else if (null_byte_found) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6466 setup_coding_system (Qno_conversion, coding); |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6467 else if ((detect_info.rejected & CATEGORY_MASK_ANY) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6468 == CATEGORY_MASK_ANY) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6469 setup_coding_system (Qraw_text, coding); |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6470 else if (detect_info.rejected) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6471 for (i = 0; i < coding_category_raw_text; i++) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6472 if (! (detect_info.rejected & (1 << coding_priorities[i]))) |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6473 { |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6474 this = coding_categories + coding_priorities[i]; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6475 setup_coding_system (CODING_ID_NAME (this->id), coding); |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6476 break; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
6477 } |
88365 | 6478 } |
6479 } | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6480 else if (XINT (CODING_ATTR_CATEGORY (CODING_ID_ATTRS (coding->id))) |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6481 == coding_category_utf_8_auto) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6482 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6483 Lisp_Object coding_systems; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6484 struct coding_detection_info detect_info; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6485 |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6486 coding_systems |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6487 = AREF (CODING_ID_ATTRS (coding->id), coding_attr_utf_bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6488 detect_info.found = detect_info.rejected = 0; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6489 coding->head_ascii = 0; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6490 if (CONSP (coding_systems) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6491 && detect_coding_utf_8 (coding, &detect_info)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6492 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6493 if (detect_info.found & CATEGORY_MASK_UTF_8_SIG) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6494 setup_coding_system (XCAR (coding_systems), coding); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6495 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6496 setup_coding_system (XCDR (coding_systems), coding); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6497 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6498 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6499 else if (XINT (CODING_ATTR_CATEGORY (CODING_ID_ATTRS (coding->id))) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6500 == coding_category_utf_16_auto) |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6501 { |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6502 Lisp_Object coding_systems; |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6503 struct coding_detection_info detect_info; |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6504 |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6505 coding_systems |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6506 = AREF (CODING_ID_ATTRS (coding->id), coding_attr_utf_bom); |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6507 detect_info.found = detect_info.rejected = 0; |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
6508 coding->head_ascii = 0; |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6509 if (CONSP (coding_systems) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6510 && detect_coding_utf_16 (coding, &detect_info)) |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6511 { |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6512 if (detect_info.found & CATEGORY_MASK_UTF_16_LE) |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6513 setup_coding_system (XCAR (coding_systems), coding); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6514 else if (detect_info.found & CATEGORY_MASK_UTF_16_BE) |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6515 setup_coding_system (XCDR (coding_systems), coding); |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6516 } |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
6517 } |
102105
a5023e8bbb1e
(detect_coding): Preserve coding->mode.
Kenichi Handa <handa@m17n.org>
parents:
102058
diff
changeset
|
6518 coding->mode = saved_mode; |
88365 | 6519 } |
6520 | |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6521 |
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6522 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6523 decode_eol (struct coding_system *coding) |
88365 | 6524 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6525 Lisp_Object eol_type; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6526 unsigned char *p, *pbeg, *pend; |
93877
62d97ebb13a9
* coding.c (detect_coding_emacs_mule)
Michael Albinus <michael.albinus@gmx.de>
parents:
93595
diff
changeset
|
6527 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6528 eol_type = CODING_ID_EOL_TYPE (coding->id); |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
6529 if (EQ (eol_type, Qunix) || inhibit_eol_conversion) |
17052 | 6530 return; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6531 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6532 if (NILP (coding->dst_object)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6533 pbeg = coding->destination; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6534 else |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6535 pbeg = BYTE_POS_ADDR (coding->dst_pos_byte); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6536 pend = pbeg + coding->produced; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6537 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6538 if (VECTORP (eol_type)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6539 { |
88365 | 6540 int eol_seen = EOL_SEEN_NONE; |
6541 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6542 for (p = pbeg; p < pend; p++) |
88365 | 6543 { |
6544 if (*p == '\n') | |
6545 eol_seen |= EOL_SEEN_LF; | |
6546 else if (*p == '\r') | |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6547 { |
88365 | 6548 if (p + 1 < pend && *(p + 1) == '\n') |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6549 { |
88365 | 6550 eol_seen |= EOL_SEEN_CRLF; |
6551 p++; | |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6552 } |
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6553 else |
88365 | 6554 eol_seen |= EOL_SEEN_CR; |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
6555 } |
28022
6c41f3276340
Add comments on coding-category-utf-8,
Kenichi Handa <handa@m17n.org>
parents:
27943
diff
changeset
|
6556 } |
101678
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6557 /* Handle DOS-style EOLs in a file with stray ^M characters. */ |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6558 if ((eol_seen & EOL_SEEN_CRLF) != 0 |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6559 && (eol_seen & EOL_SEEN_CR) != 0 |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6560 && (eol_seen & EOL_SEEN_LF) == 0) |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6561 eol_seen = EOL_SEEN_CRLF; |
589af07b7af1
(detect_eol, decode_eol): Handle text with DOS-style EOLs that also has
Eli Zaretskii <eliz@gnu.org>
parents:
101197
diff
changeset
|
6562 else if (eol_seen != EOL_SEEN_NONE |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6563 && eol_seen != EOL_SEEN_LF |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6564 && eol_seen != EOL_SEEN_CRLF |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6565 && eol_seen != EOL_SEEN_CR) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6566 eol_seen = EOL_SEEN_LF; |
88365 | 6567 if (eol_seen != EOL_SEEN_NONE) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6568 eol_type = adjust_coding_eol_type (coding, eol_seen); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6569 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6570 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6571 if (EQ (eol_type, Qmac)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6572 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6573 for (p = pbeg; p < pend; p++) |
88365 | 6574 if (*p == '\r') |
6575 *p = '\n'; | |
6576 } | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6577 else if (EQ (eol_type, Qdos)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6578 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6579 int n = 0; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6580 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6581 if (NILP (coding->dst_object)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6582 { |
90378
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6583 /* Start deleting '\r' from the tail to minimize the memory |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6584 movement. */ |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6585 for (p = pend - 2; p >= pbeg; p--) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6586 if (*p == '\r') |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6587 { |
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109159
diff
changeset
|
6588 memmove (p, p + 1, pend-- - p - 1); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6589 n++; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6590 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6591 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6592 else |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6593 { |
90378
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6594 int pos_byte = coding->dst_pos_byte; |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6595 int pos = coding->dst_pos; |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6596 int pos_end = pos + coding->produced_char - 1; |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6597 |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6598 while (pos < pos_end) |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6599 { |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6600 p = BYTE_POS_ADDR (pos_byte); |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6601 if (*p == '\r' && p[1] == '\n') |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6602 { |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6603 del_range_2 (pos, pos_byte, pos + 1, pos_byte + 1, 0); |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6604 n++; |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6605 pos_end--; |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6606 } |
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6607 pos++; |
91535
419a669bc4f2
(decode_eol): Pay attention to coding->dst_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
91367
diff
changeset
|
6608 if (coding->dst_multibyte) |
419a669bc4f2
(decode_eol): Pay attention to coding->dst_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
91367
diff
changeset
|
6609 pos_byte += BYTES_BY_CHAR_HEAD (*p); |
419a669bc4f2
(decode_eol): Pay attention to coding->dst_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
91367
diff
changeset
|
6610 else |
419a669bc4f2
(decode_eol): Pay attention to coding->dst_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
91367
diff
changeset
|
6611 pos_byte++; |
90378
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
6612 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6613 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6614 coding->produced -= n; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
6615 coding->produced_char -= n; |
17052 | 6616 } |
6617 } | |
6618 | |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6619 |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
6620 /* Return a translation table (or list of them) from coding system |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
6621 attribute vector ATTRS for encoding (ENCODEP is nonzero) or |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
6622 decoding (ENCODEP is zero). */ |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6623 |
89858
23cb9ed79225
(get_translation_table): Declare it as Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
89856
diff
changeset
|
6624 static Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6625 get_translation_table (Lisp_Object attrs, int encodep, int *max_lookup) |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6626 { |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6627 Lisp_Object standard, translation_table; |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6628 Lisp_Object val; |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6629 |
103306
3680b4fe0f79
* coding.c (get_translation_table): Check Venable_character_translation.
Chong Yidong <cyd@stupidchicken.com>
parents:
103133
diff
changeset
|
6630 if (NILP (Venable_character_translation)) |
3680b4fe0f79
* coding.c (get_translation_table): Check Venable_character_translation.
Chong Yidong <cyd@stupidchicken.com>
parents:
103133
diff
changeset
|
6631 { |
3680b4fe0f79
* coding.c (get_translation_table): Check Venable_character_translation.
Chong Yidong <cyd@stupidchicken.com>
parents:
103133
diff
changeset
|
6632 if (max_lookup) |
3680b4fe0f79
* coding.c (get_translation_table): Check Venable_character_translation.
Chong Yidong <cyd@stupidchicken.com>
parents:
103133
diff
changeset
|
6633 *max_lookup = 0; |
3680b4fe0f79
* coding.c (get_translation_table): Check Venable_character_translation.
Chong Yidong <cyd@stupidchicken.com>
parents:
103133
diff
changeset
|
6634 return Qnil; |
3680b4fe0f79
* coding.c (get_translation_table): Check Venable_character_translation.
Chong Yidong <cyd@stupidchicken.com>
parents:
103133
diff
changeset
|
6635 } |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6636 if (encodep) |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6637 translation_table = CODING_ATTR_ENCODE_TBL (attrs), |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6638 standard = Vstandard_translation_table_for_encode; |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6639 else |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6640 translation_table = CODING_ATTR_DECODE_TBL (attrs), |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6641 standard = Vstandard_translation_table_for_decode; |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
6642 if (NILP (translation_table)) |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6643 translation_table = standard; |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6644 else |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6645 { |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6646 if (SYMBOLP (translation_table)) |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6647 translation_table = Fget (translation_table, Qtranslation_table); |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6648 else if (CONSP (translation_table)) |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6649 { |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6650 translation_table = Fcopy_sequence (translation_table); |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6651 for (val = translation_table; CONSP (val); val = XCDR (val)) |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6652 if (SYMBOLP (XCAR (val))) |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6653 XSETCAR (val, Fget (XCAR (val), Qtranslation_table)); |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6654 } |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6655 if (CHAR_TABLE_P (standard)) |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6656 { |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6657 if (CONSP (translation_table)) |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6658 translation_table = nconc2 (translation_table, |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6659 Fcons (standard, Qnil)); |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6660 else |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6661 translation_table = Fcons (translation_table, |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6662 Fcons (standard, Qnil)); |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6663 } |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6664 } |
89861
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6665 |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6666 if (max_lookup) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6667 { |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6668 *max_lookup = 1; |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6669 if (CHAR_TABLE_P (translation_table) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6670 && CHAR_TABLE_EXTRA_SLOTS (XCHAR_TABLE (translation_table)) > 1) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6671 { |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6672 val = XCHAR_TABLE (translation_table)->extras[1]; |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6673 if (NATNUMP (val) && *max_lookup < XFASTINT (val)) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6674 *max_lookup = XFASTINT (val); |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6675 } |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6676 else if (CONSP (translation_table)) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6677 { |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6678 Lisp_Object tail, val; |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6679 |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6680 for (tail = translation_table; CONSP (tail); tail = XCDR (tail)) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6681 if (CHAR_TABLE_P (XCAR (tail)) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6682 && CHAR_TABLE_EXTRA_SLOTS (XCHAR_TABLE (XCAR (tail))) > 1) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6683 { |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6684 val = XCHAR_TABLE (XCAR (tail))->extras[1]; |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6685 if (NATNUMP (val) && *max_lookup < XFASTINT (val)) |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6686 *max_lookup = XFASTINT (val); |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6687 } |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
6688 } |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
6689 } |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6690 return translation_table; |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6691 } |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6692 |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6693 #define LOOKUP_TRANSLATION_TABLE(table, c, trans) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6694 do { \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6695 trans = Qnil; \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6696 if (CHAR_TABLE_P (table)) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6697 { \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6698 trans = CHAR_TABLE_REF (table, c); \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6699 if (CHARACTERP (trans)) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6700 c = XFASTINT (trans), trans = Qnil; \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6701 } \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6702 else if (CONSP (table)) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6703 { \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6704 Lisp_Object tail; \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6705 \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6706 for (tail = table; CONSP (tail); tail = XCDR (tail)) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6707 if (CHAR_TABLE_P (XCAR (tail))) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6708 { \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6709 trans = CHAR_TABLE_REF (XCAR (tail), c); \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6710 if (CHARACTERP (trans)) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6711 c = XFASTINT (trans), trans = Qnil; \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6712 else if (! NILP (trans)) \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6713 break; \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6714 } \ |
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6715 } \ |
89858
23cb9ed79225
(get_translation_table): Declare it as Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
89856
diff
changeset
|
6716 } while (0) |
23cb9ed79225
(get_translation_table): Declare it as Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
89856
diff
changeset
|
6717 |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
6718 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6719 /* Return a translation of character(s) at BUF according to TRANS. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6720 TRANS is TO-CHAR or ((FROM . TO) ...) where |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6721 FROM = [FROM-CHAR ...], TO is TO-CHAR or [TO-CHAR ...]. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6722 The return value is TO-CHAR or ([FROM-CHAR ...] . TO) if a |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6723 translation is found, and Qnil if not found.. |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6724 If BUF is too short to lookup characters in FROM, return Qt. */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6725 |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6726 static Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6727 get_translation (Lisp_Object trans, int *buf, int *buf_end) |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6728 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6729 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6730 if (INTEGERP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6731 return trans; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6732 for (; CONSP (trans); trans = XCDR (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6733 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6734 Lisp_Object val = XCAR (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6735 Lisp_Object from = XCAR (val); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6736 int len = ASIZE (from); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6737 int i; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6738 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6739 for (i = 0; i < len; i++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6740 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6741 if (buf + i == buf_end) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6742 return Qt; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6743 if (XINT (AREF (from, i)) != buf[i]) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6744 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6745 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6746 if (i == len) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6747 return val; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6748 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6749 return Qnil; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6750 } |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6751 |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6752 |
88365 | 6753 static int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
6754 produce_chars (struct coding_system *coding, Lisp_Object translation_table, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
6755 int last_block) |
17052 | 6756 { |
88365 | 6757 unsigned char *dst = coding->destination + coding->produced; |
6758 unsigned char *dst_end = coding->destination + coding->dst_bytes; | |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6759 EMACS_INT produced; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6760 EMACS_INT produced_chars = 0; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6761 int carryover = 0; |
88365 | 6762 |
6763 if (! coding->chars_at_source) | |
6764 { | |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6765 /* Source characters are in coding->charbuf. */ |
89575
59d10ebd2a0b
(produce_chars): Revert last change.
Andreas Schwab <schwab@suse.de>
parents:
89571
diff
changeset
|
6766 int *buf = coding->charbuf; |
59d10ebd2a0b
(produce_chars): Revert last change.
Andreas Schwab <schwab@suse.de>
parents:
89571
diff
changeset
|
6767 int *buf_end = buf + coding->charbuf_used; |
88365 | 6768 |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6769 if (EQ (coding->src_object, coding->dst_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6770 { |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6771 coding_set_source (coding); |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6772 dst_end = ((unsigned char *) coding->source) + coding->consumed; |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6773 } |
88365 | 6774 |
6775 while (buf < buf_end) | |
6776 { | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6777 int c = *buf, i; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6778 |
88365 | 6779 if (c >= 0) |
6780 { | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6781 int from_nchars = 1, to_nchars = 1; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6782 Lisp_Object trans = Qnil; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6783 |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
6784 LOOKUP_TRANSLATION_TABLE (translation_table, c, trans); |
89858
23cb9ed79225
(get_translation_table): Declare it as Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
89856
diff
changeset
|
6785 if (! NILP (trans)) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6786 { |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6787 trans = get_translation (trans, buf, buf_end); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6788 if (INTEGERP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6789 c = XINT (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6790 else if (CONSP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6791 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6792 from_nchars = ASIZE (XCAR (trans)); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6793 trans = XCDR (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6794 if (INTEGERP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6795 c = XINT (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6796 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6797 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6798 to_nchars = ASIZE (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6799 c = XINT (AREF (trans, 0)); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6800 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6801 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6802 else if (EQ (trans, Qt) && ! last_block) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6803 break; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6804 } |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6805 |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6806 if (dst + MAX_MULTIBYTE_LENGTH * to_nchars > dst_end) |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6807 { |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6808 dst = alloc_destination (coding, |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6809 buf_end - buf |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6810 + MAX_MULTIBYTE_LENGTH * to_nchars, |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6811 dst); |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6812 if (EQ (coding->src_object, coding->dst_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6813 { |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6814 coding_set_source (coding); |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6815 dst_end = (((unsigned char *) coding->source) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6816 + coding->consumed); |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6817 } |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6818 else |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6819 dst_end = coding->destination + coding->dst_bytes; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6820 } |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6821 |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
6822 for (i = 0; i < to_nchars; i++) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6823 { |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
6824 if (i > 0) |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
6825 c = XINT (AREF (trans, i)); |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6826 if (coding->dst_multibyte |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6827 || ! CHAR_BYTE8_P (c)) |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6828 CHAR_STRING_ADVANCE_NO_UNIFY (c, dst); |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6829 else |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6830 *dst++ = CHAR_TO_BYTE8 (c); |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6831 } |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6832 produced_chars += to_nchars; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6833 buf += from_nchars; |
88365 | 6834 } |
6835 else | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6836 /* This is an annotation datum. (-C) is the length. */ |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6837 buf += -c; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6838 } |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6839 carryover = buf_end - buf; |
30833
2db6e42a6ba3
(MINIMUM_CONVERSION_BUFFER_SIZE): Macro deleted.
Kenichi Handa <handa@m17n.org>
parents:
30756
diff
changeset
|
6840 } |
2db6e42a6ba3
(MINIMUM_CONVERSION_BUFFER_SIZE): Macro deleted.
Kenichi Handa <handa@m17n.org>
parents:
30756
diff
changeset
|
6841 else |
2db6e42a6ba3
(MINIMUM_CONVERSION_BUFFER_SIZE): Macro deleted.
Kenichi Handa <handa@m17n.org>
parents:
30756
diff
changeset
|
6842 { |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6843 /* Source characters are at coding->source. */ |
89483 | 6844 const unsigned char *src = coding->source; |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6845 const unsigned char *src_end = src + coding->consumed; |
88365 | 6846 |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6847 if (EQ (coding->dst_object, coding->src_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6848 dst_end = (unsigned char *) src; |
88365 | 6849 if (coding->src_multibyte != coding->dst_multibyte) |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6850 { |
88365 | 6851 if (coding->src_multibyte) |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6852 { |
88443
6b86cf30a0b9
(produce_chars): Set the variable `multibytep' correctly.
Kenichi Handa <handa@m17n.org>
parents:
88438
diff
changeset
|
6853 int multibytep = 1; |
100135
0e17542db552
(detect_coding_system): Initialize utf_16_le_eol to -1, val to
Kenichi Handa <handa@m17n.org>
parents:
100133
diff
changeset
|
6854 EMACS_INT consumed_chars = 0; |
88365 | 6855 |
6856 while (1) | |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6857 { |
89483 | 6858 const unsigned char *src_base = src; |
88365 | 6859 int c; |
6860 | |
6861 ONE_MORE_BYTE (c); | |
6862 if (dst == dst_end) | |
6863 { | |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6864 if (EQ (coding->src_object, coding->dst_object)) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6865 dst_end = (unsigned char *) src; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6866 if (dst == dst_end) |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6867 { |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6868 EMACS_INT offset = src - coding->source; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6869 |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6870 dst = alloc_destination (coding, src_end - src + 1, |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6871 dst); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6872 dst_end = coding->destination + coding->dst_bytes; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6873 coding_set_source (coding); |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6874 src = coding->source + offset; |
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6875 src_end = coding->source + coding->src_bytes; |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6876 if (EQ (coding->src_object, coding->dst_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6877 dst_end = (unsigned char *) src; |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6878 } |
88365 | 6879 } |
6880 *dst++ = c; | |
6881 produced_chars++; | |
6882 } | |
6883 no_more_source: | |
6884 ; | |
6885 } | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6886 else |
88365 | 6887 while (src < src_end) |
6888 { | |
88443
6b86cf30a0b9
(produce_chars): Set the variable `multibytep' correctly.
Kenichi Handa <handa@m17n.org>
parents:
88438
diff
changeset
|
6889 int multibytep = 1; |
88365 | 6890 int c = *src++; |
6891 | |
6892 if (dst >= dst_end - 1) | |
6893 { | |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6894 if (EQ (coding->src_object, coding->dst_object)) |
89483 | 6895 dst_end = (unsigned char *) src; |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6896 if (dst >= dst_end - 1) |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6897 { |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6898 EMACS_INT offset = src - coding->source; |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6899 EMACS_INT more_bytes; |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6900 |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6901 if (EQ (coding->src_object, coding->dst_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6902 more_bytes = ((src_end - src) / 2) + 2; |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6903 else |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6904 more_bytes = src_end - src + 2; |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6905 dst = alloc_destination (coding, more_bytes, dst); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6906 dst_end = coding->destination + coding->dst_bytes; |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6907 coding_set_source (coding); |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6908 src = coding->source + offset; |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6909 src_end = coding->source + coding->src_bytes; |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6910 if (EQ (coding->src_object, coding->dst_object)) |
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
6911 dst_end = (unsigned char *) src; |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
6912 } |
88365 | 6913 } |
6914 EMIT_ONE_BYTE (c); | |
6915 } | |
6916 } | |
6917 else | |
6918 { | |
6919 if (!EQ (coding->src_object, coding->dst_object)) | |
6920 { | |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6921 EMACS_INT require = coding->src_bytes - coding->dst_bytes; |
88365 | 6922 |
6923 if (require > 0) | |
23325
bbd06336cd0c
(check_composing_code): If the current composing
Kenichi Handa <handa@m17n.org>
parents:
23315
diff
changeset
|
6924 { |
88365 | 6925 EMACS_INT offset = src - coding->source; |
6926 | |
6927 dst = alloc_destination (coding, require, dst); | |
6928 coding_set_source (coding); | |
6929 src = coding->source + offset; | |
6930 src_end = coding->source + coding->src_bytes; | |
23325
bbd06336cd0c
(check_composing_code): If the current composing
Kenichi Handa <handa@m17n.org>
parents:
23315
diff
changeset
|
6931 } |
34892
3868f2e7355a
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
34888
diff
changeset
|
6932 } |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6933 produced_chars = coding->consumed_char; |
88365 | 6934 while (src < src_end) |
92406
c36bda0a03cc
(decode_coding_big5, produce_chars): Fix typos in last
Andreas Schwab <schwab@suse.de>
parents:
92399
diff
changeset
|
6935 *dst++ = *src++; |
92399
fbc07b3a6baf
(decode_coding_utf_8): When eol-type of CODING is
Kenichi Handa <handa@m17n.org>
parents:
92030
diff
changeset
|
6936 } |
88365 | 6937 } |
6938 | |
6939 produced = dst - (coding->destination + coding->produced); | |
90809
3c52757d5f6e
(produce_chars): Don't call insert_from_gap if no
Kenichi Handa <handa@m17n.org>
parents:
90772
diff
changeset
|
6940 if (BUFFERP (coding->dst_object) && produced_chars > 0) |
88365 | 6941 insert_from_gap (produced_chars, produced); |
6942 coding->produced += produced; | |
6943 coding->produced_char += produced_chars; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6944 return carryover; |
88365 | 6945 } |
6946 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6947 /* Compose text in CODING->object according to the annotation data at |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6948 CHARBUF. CHARBUF is an array: |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6949 [ -LENGTH ANNOTATION_MASK NCHARS NBYTES METHOD [ COMPONENTS... ] ] |
88365 | 6950 */ |
6951 | |
6952 static INLINE void | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6953 produce_composition (struct coding_system *coding, int *charbuf, EMACS_INT pos) |
88365 | 6954 { |
6955 int len; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6956 EMACS_INT to; |
88365 | 6957 enum composition_method method; |
6958 Lisp_Object components; | |
6959 | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6960 len = -charbuf[0] - MAX_ANNOTATION_LENGTH; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6961 to = pos + charbuf[2]; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6962 method = (enum composition_method) (charbuf[4]); |
88365 | 6963 |
6964 if (method == COMPOSITION_RELATIVE) | |
6965 components = Qnil; | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6966 else |
88365 | 6967 { |
6968 Lisp_Object args[MAX_COMPOSITION_COMPONENTS * 2 - 1]; | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6969 int i, j; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6970 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6971 if (method == COMPOSITION_WITH_RULE) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6972 len = charbuf[2] * 3 - 2; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6973 charbuf += MAX_ANNOTATION_LENGTH; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6974 /* charbuf = [ CHRA ... CHAR] or [ CHAR -2 RULE ... CHAR ] */ |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6975 for (i = j = 0; i < len && charbuf[i] != -1; i++, j++) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6976 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6977 if (charbuf[i] >= 0) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6978 args[j] = make_number (charbuf[i]); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6979 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6980 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6981 i++; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6982 args[j] = make_number (charbuf[i] % 0x100); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6983 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6984 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6985 components = (i == j ? Fstring (j, args) : Fvector (j, args)); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
6986 } |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6987 compose_text (pos, to, components, Qnil, coding->dst_object); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6988 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
6989 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6990 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6991 /* Put `charset' property on text in CODING->object according to |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6992 the annotation data at CHARBUF. CHARBUF is an array: |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6993 [ -LENGTH ANNOTATION_MASK NCHARS CHARSET-ID ] |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6994 */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6995 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
6996 static INLINE void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
6997 produce_charset (struct coding_system *coding, int *charbuf, EMACS_INT pos) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6998 { |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
6999 EMACS_INT from = pos - charbuf[2]; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7000 struct charset *charset = CHARSET_FROM_ID (charbuf[3]); |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7001 |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7002 Fput_text_property (make_number (from), make_number (pos), |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7003 Qcharset, CHARSET_NAME (charset), |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7004 coding->dst_object); |
88365 | 7005 } |
7006 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7007 |
88365 | 7008 #define CHARBUF_SIZE 0x4000 |
7009 | |
7010 #define ALLOC_CONVERSION_WORK_AREA(coding) \ | |
7011 do { \ | |
101943
97c9e9322753
Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents:
101904
diff
changeset
|
7012 int size = CHARBUF_SIZE; \ |
88365 | 7013 \ |
7014 coding->charbuf = NULL; \ | |
7015 while (size > 1024) \ | |
7016 { \ | |
7017 coding->charbuf = (int *) alloca (sizeof (int) * size); \ | |
7018 if (coding->charbuf) \ | |
7019 break; \ | |
7020 size >>= 1; \ | |
7021 } \ | |
7022 if (! coding->charbuf) \ | |
7023 { \ | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7024 record_conversion_result (coding, CODING_RESULT_INSUFFICIENT_MEM); \ |
88365 | 7025 return coding->result; \ |
7026 } \ | |
7027 coding->charbuf_size = size; \ | |
7028 } while (0) | |
7029 | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7030 |
30833
2db6e42a6ba3
(MINIMUM_CONVERSION_BUFFER_SIZE): Macro deleted.
Kenichi Handa <handa@m17n.org>
parents:
30756
diff
changeset
|
7031 static void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
7032 produce_annotation (struct coding_system *coding, EMACS_INT pos) |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7033 { |
88365 | 7034 int *charbuf = coding->charbuf; |
7035 int *charbuf_end = charbuf + coding->charbuf_used; | |
7036 | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7037 if (NILP (coding->dst_object)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7038 return; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7039 |
88365 | 7040 while (charbuf < charbuf_end) |
7041 { | |
7042 if (*charbuf >= 0) | |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7043 pos++, charbuf++; |
88365 | 7044 else |
29877
7b43e1fb478a
(decode_eol_post_ccl): Special handling for undecided
Eli Zaretskii <eliz@gnu.org>
parents:
29725
diff
changeset
|
7045 { |
88365 | 7046 int len = -*charbuf; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7047 |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7048 if (len > 2) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7049 switch (charbuf[1]) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7050 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7051 case CODING_ANNOTATE_COMPOSITION_MASK: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7052 produce_composition (coding, charbuf, pos); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7053 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7054 case CODING_ANNOTATE_CHARSET_MASK: |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7055 produce_charset (coding, charbuf, pos); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7056 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7057 } |
88365 | 7058 charbuf += len; |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7059 } |
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7060 } |
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7061 } |
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7062 |
88365 | 7063 /* Decode the data at CODING->src_object into CODING->dst_object. |
7064 CODING->src_object is a buffer, a string, or nil. | |
7065 CODING->dst_object is a buffer. | |
7066 | |
7067 If CODING->src_object is a buffer, it must be the current buffer. | |
7068 In this case, if CODING->src_pos is positive, it is a position of | |
7069 the source text in the buffer, otherwise, the source text is in the | |
7070 gap area of the buffer, and CODING->src_pos specifies the offset of | |
7071 the text from GPT (which must be the same as PT). If this is the | |
7072 same buffer as CODING->dst_object, CODING->src_pos must be | |
7073 negative. | |
7074 | |
90380
4bf7966e0788
(decode_coding): Typo in comment fixed.
Kenichi Handa <handa@m17n.org>
parents:
90378
diff
changeset
|
7075 If CODING->src_object is a string, CODING->src_pos is an index to |
88365 | 7076 that string. |
7077 | |
7078 If CODING->src_object is nil, CODING->source must already point to | |
7079 the non-relocatable memory area. In this case, CODING->src_pos is | |
7080 an offset from CODING->source. | |
7081 | |
7082 The decoded data is inserted at the current point of the buffer | |
7083 CODING->dst_object. | |
7084 */ | |
7085 | |
7086 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
7087 decode_coding (struct coding_system *coding) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7088 { |
88365 | 7089 Lisp_Object attrs; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7090 Lisp_Object undo_list; |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
7091 Lisp_Object translation_table; |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7092 struct ccl_spec cclspec; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7093 int carryover; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7094 int i; |
88365 | 7095 |
7096 if (BUFFERP (coding->src_object) | |
7097 && coding->src_pos > 0 | |
7098 && coding->src_pos < GPT | |
7099 && coding->src_pos + coding->src_chars > GPT) | |
7100 move_gap_both (coding->src_pos, coding->src_pos_byte); | |
7101 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7102 undo_list = Qt; |
88365 | 7103 if (BUFFERP (coding->dst_object)) |
7104 { | |
7105 if (current_buffer != XBUFFER (coding->dst_object)) | |
7106 set_buffer_internal (XBUFFER (coding->dst_object)); | |
7107 if (GPT != PT) | |
7108 move_gap_both (PT, PT_BYTE); | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7109 undo_list = current_buffer->undo_list; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7110 current_buffer->undo_list = Qt; |
88365 | 7111 } |
7112 | |
7113 coding->consumed = coding->consumed_char = 0; | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
7114 coding->produced = coding->produced_char = 0; |
88365 | 7115 coding->chars_at_source = 0; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7116 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
7117 coding->errors = 0; |
88365 | 7118 |
7119 ALLOC_CONVERSION_WORK_AREA (coding); | |
7120 | |
7121 attrs = CODING_ID_ATTRS (coding->id); | |
89861
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
7122 translation_table = get_translation_table (attrs, 0, NULL); |
88365 | 7123 |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7124 carryover = 0; |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7125 if (coding->decoder == decode_coding_ccl) |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7126 { |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7127 coding->spec.ccl = &cclspec; |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7128 setup_ccl_program (&cclspec.ccl, CODING_CCL_DECODER (coding)); |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7129 } |
88365 | 7130 do |
7131 { | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7132 EMACS_INT pos = coding->dst_pos + coding->produced_char; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7133 |
88365 | 7134 coding_set_source (coding); |
7135 coding->annotated = 0; | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7136 coding->charbuf_used = carryover; |
88365 | 7137 (*(coding->decoder)) (coding); |
7138 coding_set_destination (coding); | |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7139 carryover = produce_chars (coding, translation_table, 0); |
88365 | 7140 if (coding->annotated) |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7141 produce_annotation (coding, pos); |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7142 for (i = 0; i < carryover; i++) |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7143 coding->charbuf[i] |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7144 = coding->charbuf[coding->charbuf_used - carryover + i]; |
88365 | 7145 } |
107171
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7146 while (coding->result == CODING_RESULT_INSUFFICIENT_DST |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7147 || (coding->consumed < coding->src_bytes |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7148 && (coding->result == CODING_RESULT_SUCCESS |
dfc03b454687
Fix the ccl decoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
106918
diff
changeset
|
7149 || coding->result == CODING_RESULT_INVALID_SRC))); |
88365 | 7150 |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7151 if (carryover > 0) |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7152 { |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7153 coding_set_destination (coding); |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7154 coding->charbuf_used = carryover; |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7155 produce_chars (coding, translation_table, 1); |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7156 } |
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7157 |
88365 | 7158 coding->carryover_bytes = 0; |
7159 if (coding->consumed < coding->src_bytes) | |
7160 { | |
7161 int nbytes = coding->src_bytes - coding->consumed; | |
89483 | 7162 const unsigned char *src; |
88365 | 7163 |
7164 coding_set_source (coding); | |
7165 coding_set_destination (coding); | |
7166 src = coding->source + coding->consumed; | |
7167 | |
7168 if (coding->mode & CODING_MODE_LAST_BLOCK) | |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7169 { |
88365 | 7170 /* Flush out unprocessed data as binary chars. We are sure |
7171 that the number of data is less than the size of | |
7172 coding->charbuf. */ | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7173 coding->charbuf_used = 0; |
100587
d91e3320dd81
(decode_coding): Clear chars_at_source flag when using charbuf.
Jason Rumney <jasonr@gnu.org>
parents:
100303
diff
changeset
|
7174 coding->chars_at_source = 0; |
d91e3320dd81
(decode_coding): Clear chars_at_source flag when using charbuf.
Jason Rumney <jasonr@gnu.org>
parents:
100303
diff
changeset
|
7175 |
88365 | 7176 while (nbytes-- > 0) |
7177 { | |
7178 int c = *src++; | |
89279
1fd77c471ee6
(decode_coding_utf_8): When eol_type is Qdos, handle
Kenichi Handa <handa@m17n.org>
parents:
89227
diff
changeset
|
7179 |
90243
c59afb15f5c6
(decode_coding): Fix handling of invalid bytes.
Kenichi Handa <handa@m17n.org>
parents:
90231
diff
changeset
|
7180 if (c & 0x80) |
c59afb15f5c6
(decode_coding): Fix handling of invalid bytes.
Kenichi Handa <handa@m17n.org>
parents:
90231
diff
changeset
|
7181 c = BYTE8_TO_CHAR (c); |
c59afb15f5c6
(decode_coding): Fix handling of invalid bytes.
Kenichi Handa <handa@m17n.org>
parents:
90231
diff
changeset
|
7182 coding->charbuf[coding->charbuf_used++] = c; |
88365 | 7183 } |
89863
428fc37b2ae6
Add many prototypes for static functions.
Kenichi Handa <handa@m17n.org>
parents:
89861
diff
changeset
|
7184 produce_chars (coding, Qnil, 1); |
29725
2bc397e9b09a
(setup_coding_system) <4>: Reset member `cr_carryover'.
Kenichi Handa <handa@m17n.org>
parents:
29663
diff
changeset
|
7185 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7186 else |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7187 { |
88365 | 7188 /* Record unprocessed bytes in coding->carryover. We are |
7189 sure that the number of data is less than the size of | |
7190 coding->carryover. */ | |
7191 unsigned char *p = coding->carryover; | |
7192 | |
102115
db1f94e25359
(detect_coding): Don't overflow coding->carryover.
Kenichi Handa <handa@m17n.org>
parents:
102105
diff
changeset
|
7193 if (nbytes > sizeof coding->carryover) |
db1f94e25359
(detect_coding): Don't overflow coding->carryover.
Kenichi Handa <handa@m17n.org>
parents:
102105
diff
changeset
|
7194 nbytes = sizeof coding->carryover; |
88365 | 7195 coding->carryover_bytes = nbytes; |
7196 while (nbytes-- > 0) | |
7197 *p++ = *src++; | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7198 } |
88365 | 7199 coding->consumed = coding->src_bytes; |
7200 } | |
7201 | |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
7202 if (! EQ (CODING_ID_EOL_TYPE (coding->id), Qunix) |
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
7203 && !inhibit_eol_conversion) |
90378
0aec08f4c729
(decode_eol): Pay attention to buffer relocation in
Kenichi Handa <handa@m17n.org>
parents:
90363
diff
changeset
|
7204 decode_eol (coding); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7205 if (BUFFERP (coding->dst_object)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7206 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7207 current_buffer->undo_list = undo_list; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7208 record_insert (coding->dst_pos, coding->produced_char); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7209 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
7210 return coding->result; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7211 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7212 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7213 |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
7214 /* Extract an annotation datum from a composition starting at POS and |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7215 ending before LIMIT of CODING->src_object (buffer or string), store |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7216 the data in BUF, set *STOP to a starting position of the next |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7217 composition (if any) or to LIMIT, and return the address of the |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7218 next element of BUF. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7219 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7220 If such an annotation is not found, set *STOP to a starting |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7221 position of a composition after POS (if any) or to LIMIT, and |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7222 return BUF. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7223 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7224 static INLINE int * |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7225 handle_composition_annotation (EMACS_INT pos, EMACS_INT limit, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7226 struct coding_system *coding, int *buf, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7227 EMACS_INT *stop) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7228 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7229 EMACS_INT start, end; |
26847 | 7230 Lisp_Object prop; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7231 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7232 if (! find_composition (pos, limit, &start, &end, &prop, coding->src_object) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7233 || end > limit) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7234 *stop = limit; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7235 else if (start > pos) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7236 *stop = start; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7237 else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7238 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7239 if (start == pos) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7240 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7241 /* We found a composition. Store the corresponding |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7242 annotation data in BUF. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7243 int *head = buf; |
26847 | 7244 enum composition_method method = COMPOSITION_METHOD (prop); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7245 int nchars = COMPOSITION_LENGTH (prop); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7246 |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7247 ADD_COMPOSITION_DATA (buf, nchars, 0, method); |
26847 | 7248 if (method != COMPOSITION_RELATIVE) |
7249 { | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7250 Lisp_Object components; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7251 int len, i, i_byte; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7252 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7253 components = COMPOSITION_COMPONENTS (prop); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7254 if (VECTORP (components)) |
26847 | 7255 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7256 len = XVECTOR (components)->size; |
26847 | 7257 for (i = 0; i < len; i++) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7258 *buf++ = XINT (AREF (components, i)); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7259 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7260 else if (STRINGP (components)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7261 { |
89483 | 7262 len = SCHARS (components); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7263 i = i_byte = 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7264 while (i < len) |
26847 | 7265 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7266 FETCH_STRING_CHAR_ADVANCE (*buf, components, i, i_byte); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7267 buf++; |
26847 | 7268 } |
7269 } | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7270 else if (INTEGERP (components)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7271 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7272 len = 1; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7273 *buf++ = XINT (components); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7274 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7275 else if (CONSP (components)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7276 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7277 for (len = 0; CONSP (components); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7278 len++, components = XCDR (components)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7279 *buf++ = XINT (XCAR (components)); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7280 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7281 else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7282 abort (); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7283 *head -= len; |
26847 | 7284 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7285 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7286 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7287 if (find_composition (end, limit, &start, &end, &prop, |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7288 coding->src_object) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7289 && end <= limit) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7290 *stop = start; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7291 else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7292 *stop = limit; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7293 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7294 return buf; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7295 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7296 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7297 |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
7298 /* Extract an annotation datum from a text property `charset' at POS of |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7299 CODING->src_object (buffer of string), store the data in BUF, set |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7300 *STOP to the position where the value of `charset' property changes |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7301 (limiting by LIMIT), and return the address of the next element of |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7302 BUF. |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7303 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7304 If the property value is nil, set *STOP to the position where the |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7305 property value is non-nil (limiting by LIMIT), and return BUF. */ |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7306 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7307 static INLINE int * |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7308 handle_charset_annotation (EMACS_INT pos, EMACS_INT limit, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7309 struct coding_system *coding, int *buf, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7310 EMACS_INT *stop) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7311 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7312 Lisp_Object val, next; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7313 int id; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7314 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7315 val = Fget_text_property (make_number (pos), Qcharset, coding->src_object); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7316 if (! NILP (val) && CHARSETP (val)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7317 id = XINT (CHARSET_SYMBOL_ID (val)); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7318 else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7319 id = -1; |
89852
b636ae1109c6
(MAX_ANNOTATION_LENGTH): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
89851
diff
changeset
|
7320 ADD_CHARSET_DATA (buf, 0, id); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7321 next = Fnext_single_property_change (make_number (pos), Qcharset, |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7322 coding->src_object, |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7323 make_number (limit)); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7324 *stop = XINT (next); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7325 return buf; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7326 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7327 |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7328 |
88365 | 7329 static void |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7330 consume_chars (struct coding_system *coding, Lisp_Object translation_table, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7331 int max_lookup) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7332 { |
88365 | 7333 int *buf = coding->charbuf; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7334 int *buf_end = coding->charbuf + coding->charbuf_size; |
88876
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
7335 const unsigned char *src = coding->source + coding->consumed; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7336 const unsigned char *src_end = coding->source + coding->src_bytes; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7337 EMACS_INT pos = coding->src_pos + coding->consumed_char; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7338 EMACS_INT end_pos = coding->src_pos + coding->src_chars; |
88365 | 7339 int multibytep = coding->src_multibyte; |
7340 Lisp_Object eol_type; | |
7341 int c; | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7342 EMACS_INT stop, stop_composition, stop_charset; |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
7343 int *lookup_buf = NULL; |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7344 |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7345 if (! NILP (translation_table)) |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
7346 lookup_buf = alloca (sizeof (int) * max_lookup); |
88365 | 7347 |
102334
7baaea85626e
(decode_coding_utf_8, decode_coding_utf_16, decode_coding_emacs_mule,
Eli Zaretskii <eliz@gnu.org>
parents:
102327
diff
changeset
|
7348 eol_type = inhibit_eol_conversion ? Qunix : CODING_ID_EOL_TYPE (coding->id); |
88365 | 7349 if (VECTORP (eol_type)) |
7350 eol_type = Qunix; | |
7351 | |
7352 /* Note: composition handling is not yet implemented. */ | |
7353 coding->common_flags &= ~CODING_ANNOTATE_COMPOSITION_MASK; | |
7354 | |
89562
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7355 if (NILP (coding->src_object)) |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7356 stop = stop_composition = stop_charset = end_pos; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7357 else |
89562
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7358 { |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7359 if (coding->common_flags & CODING_ANNOTATE_COMPOSITION_MASK) |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7360 stop = stop_composition = pos; |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7361 else |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7362 stop = stop_composition = end_pos; |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7363 if (coding->common_flags & CODING_ANNOTATE_CHARSET_MASK) |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7364 stop = stop_charset = pos; |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7365 else |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7366 stop_charset = end_pos; |
12fbcfebb9ad
(consume_chars): If coding->src_object is nil, don't check annotation.
Kenichi Handa <handa@m17n.org>
parents:
89545
diff
changeset
|
7367 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7368 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7369 /* Compensate for CRLF and conversion. */ |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7370 buf_end -= 1 + MAX_ANNOTATION_LENGTH; |
88365 | 7371 while (buf < buf_end) |
7372 { | |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7373 Lisp_Object trans; |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7374 |
88365 | 7375 if (pos == stop) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7376 { |
88365 | 7377 if (pos == end_pos) |
7378 break; | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7379 if (pos == stop_composition) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7380 buf = handle_composition_annotation (pos, end_pos, coding, |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7381 buf, &stop_composition); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7382 if (pos == stop_charset) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7383 buf = handle_charset_annotation (pos, end_pos, coding, |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7384 buf, &stop_charset); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7385 stop = (stop_composition < stop_charset |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7386 ? stop_composition : stop_charset); |
88365 | 7387 } |
7388 | |
7389 if (! multibytep) | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7390 { |
89462
4e359ebf3984
(decode_coding_iso_2022): Fix handling of invalid
Kenichi Handa <handa@m17n.org>
parents:
89448
diff
changeset
|
7391 EMACS_INT bytes; |
4e359ebf3984
(decode_coding_iso_2022): Fix handling of invalid
Kenichi Handa <handa@m17n.org>
parents:
89448
diff
changeset
|
7392 |
106918
d6e8fa5622b7
Fix ccl encoding of unibyte source.
Kenichi Handa <handa@m17n.org>
parents:
106826
diff
changeset
|
7393 if (coding->encoder == encode_coding_raw_text |
d6e8fa5622b7
Fix ccl encoding of unibyte source.
Kenichi Handa <handa@m17n.org>
parents:
106826
diff
changeset
|
7394 || coding->encoder == encode_coding_ccl) |
89933
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
7395 c = *src++, pos++; |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
7396 else if ((bytes = MULTIBYTE_LENGTH (src, src_end)) > 0) |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
7397 c = STRING_CHAR_ADVANCE_NO_UNIFY (src), pos += bytes; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7398 else |
89917
1763eef5ad02
(encode_coding_utf_8): Fix handling of raw-byte char.
Kenichi Handa <handa@m17n.org>
parents:
89905
diff
changeset
|
7399 c = BYTE8_TO_CHAR (*src), src++, pos++; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7400 } |
88365 | 7401 else |
92992
49c4ea77b83a
(CHAR_STRING_ADVANCE_NO_UNIFY)
Kenichi Handa <handa@m17n.org>
parents:
92458
diff
changeset
|
7402 c = STRING_CHAR_ADVANCE_NO_UNIFY (src), pos++; |
88365 | 7403 if ((c == '\r') && (coding->mode & CODING_MODE_SELECTIVE_DISPLAY)) |
7404 c = '\n'; | |
7405 if (! EQ (eol_type, Qunix)) | |
7406 { | |
7407 if (c == '\n') | |
32443
57fa108c491f
(code_convert_region): Be sure to initialize coding->category_idx.
Kenichi Handa <handa@m17n.org>
parents:
31458
diff
changeset
|
7408 { |
88365 | 7409 if (EQ (eol_type, Qdos)) |
7410 *buf++ = '\r'; | |
7411 else | |
7412 c = '\r'; | |
32443
57fa108c491f
(code_convert_region): Be sure to initialize coding->category_idx.
Kenichi Handa <handa@m17n.org>
parents:
31458
diff
changeset
|
7413 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7414 } |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7415 |
89858
23cb9ed79225
(get_translation_table): Declare it as Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
89856
diff
changeset
|
7416 trans = Qnil; |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
7417 LOOKUP_TRANSLATION_TABLE (translation_table, c, trans); |
89858
23cb9ed79225
(get_translation_table): Declare it as Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
89856
diff
changeset
|
7418 if (NILP (trans)) |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7419 *buf++ = c; |
26847 | 7420 else |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7421 { |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7422 int from_nchars = 1, to_nchars = 1; |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7423 int *lookup_buf_end; |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7424 const unsigned char *p = src; |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7425 int i; |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7426 |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7427 lookup_buf[0] = c; |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7428 for (i = 1; i < max_lookup && p < src_end; i++) |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7429 lookup_buf[i] = STRING_CHAR_ADVANCE (p); |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7430 lookup_buf_end = lookup_buf + i; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7431 trans = get_translation (trans, lookup_buf, lookup_buf_end); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7432 if (INTEGERP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7433 c = XINT (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7434 else if (CONSP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7435 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7436 from_nchars = ASIZE (XCAR (trans)); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7437 trans = XCDR (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7438 if (INTEGERP (trans)) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7439 c = XINT (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7440 else |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7441 { |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7442 to_nchars = ASIZE (trans); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7443 if (buf + to_nchars > buf_end) |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7444 break; |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7445 c = XINT (AREF (trans, 0)); |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7446 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7447 } |
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7448 else |
23881
20d595402dea
(DECODE_DESIGNATION): Jump to label_invalid_code if
Kenichi Handa <handa@m17n.org>
parents:
23564
diff
changeset
|
7449 break; |
102422
82f82b92314e
(CODING_ISO_CMP_STATUS): New macro.
Kenichi Handa <handa@m17n.org>
parents:
102334
diff
changeset
|
7450 *buf++ = c; |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7451 for (i = 1; i < to_nchars; i++) |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7452 *buf++ = XINT (AREF (trans, i)); |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7453 for (i = 1; i < from_nchars; i++, pos++) |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7454 src += MULTIBYTE_LENGTH_NO_CHECK (src); |
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
7455 } |
88365 | 7456 } |
7457 | |
7458 coding->consumed = src - coding->source; | |
7459 coding->consumed_char = pos - coding->src_pos; | |
7460 coding->charbuf_used = buf - coding->charbuf; | |
7461 coding->chars_at_source = 0; | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7462 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7463 |
88365 | 7464 |
7465 /* Encode the text at CODING->src_object into CODING->dst_object. | |
7466 CODING->src_object is a buffer or a string. | |
7467 CODING->dst_object is a buffer or nil. | |
7468 | |
7469 If CODING->src_object is a buffer, it must be the current buffer. | |
7470 In this case, if CODING->src_pos is positive, it is a position of | |
7471 the source text in the buffer, otherwise. the source text is in the | |
7472 gap area of the buffer, and coding->src_pos specifies the offset of | |
7473 the text from GPT (which must be the same as PT). If this is the | |
7474 same buffer as CODING->dst_object, CODING->src_pos must be | |
7475 negative and CODING should not have `pre-write-conversion'. | |
7476 | |
7477 If CODING->src_object is a string, CODING should not have | |
7478 `pre-write-conversion'. | |
7479 | |
7480 If CODING->dst_object is a buffer, the encoded data is inserted at | |
7481 the current point of that buffer. | |
7482 | |
7483 If CODING->dst_object is nil, the encoded data is placed at the | |
7484 memory area specified by CODING->destination. */ | |
7485 | |
7486 static int | |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
7487 encode_coding (struct coding_system *coding) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7488 { |
88365 | 7489 Lisp_Object attrs; |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
7490 Lisp_Object translation_table; |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
7491 int max_lookup; |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
7492 struct ccl_spec cclspec; |
88365 | 7493 |
7494 attrs = CODING_ID_ATTRS (coding->id); | |
89933
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
7495 if (coding->encoder == encode_coding_raw_text) |
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
7496 translation_table = Qnil, max_lookup = 0; |
42661
e85e4d9494b1
(code_convert_region): Don't copy old text if undo disabled.
Richard M. Stallman <rms@gnu.org>
parents:
42105
diff
changeset
|
7497 else |
89933
48af0ea7d387
(setup_coding_system): Set coding->common_flags
Kenichi Handa <handa@m17n.org>
parents:
89924
diff
changeset
|
7498 translation_table = get_translation_table (attrs, 1, &max_lookup); |
88365 | 7499 |
7500 if (BUFFERP (coding->dst_object)) | |
7501 { | |
7502 set_buffer_internal (XBUFFER (coding->dst_object)); | |
7503 coding->dst_multibyte | |
7504 = ! NILP (current_buffer->enable_multibyte_characters); | |
7505 } | |
7506 | |
7507 coding->consumed = coding->consumed_char = 0; | |
7508 coding->produced = coding->produced_char = 0; | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7509 record_conversion_result (coding, CODING_RESULT_SUCCESS); |
88365 | 7510 coding->errors = 0; |
7511 | |
7512 ALLOC_CONVERSION_WORK_AREA (coding); | |
7513 | |
107507
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
7514 if (coding->encoder == encode_coding_ccl) |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
7515 { |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
7516 coding->spec.ccl = &cclspec; |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
7517 setup_ccl_program (&cclspec.ccl, CODING_CCL_ENCODER (coding)); |
8960853cf85d
Fix the ccl encoder for the case that the output buffer is fullfilled.
Kenichi Handa <handa@m17n.org>
parents:
107506
diff
changeset
|
7518 } |
88365 | 7519 do { |
7520 coding_set_source (coding); | |
89859
b706c5ee6492
(get_translation_table): New arg max_lookup. Caller changed.
Kenichi Handa <handa@m17n.org>
parents:
89858
diff
changeset
|
7521 consume_chars (coding, translation_table, max_lookup); |
88365 | 7522 coding_set_destination (coding); |
7523 (*(coding->encoder)) (coding); | |
7524 } while (coding->consumed_char < coding->src_chars); | |
7525 | |
90809
3c52757d5f6e
(produce_chars): Don't call insert_from_gap if no
Kenichi Handa <handa@m17n.org>
parents:
90772
diff
changeset
|
7526 if (BUFFERP (coding->dst_object) && coding->produced_char > 0) |
88365 | 7527 insert_from_gap (coding->produced_char, coding->produced); |
7528 | |
7529 return (coding->result); | |
7530 } | |
7531 | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7532 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7533 /* Name (or base name) of work buffer for code conversion. */ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7534 static Lisp_Object Vcode_conversion_workbuf_name; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7535 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7536 /* A working buffer used by the top level conversion. Once it is |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7537 created, it is never destroyed. It has the name |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7538 Vcode_conversion_workbuf_name. The other working buffers are |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7539 destroyed after the use is finished, and their names are modified |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7540 versions of Vcode_conversion_workbuf_name. */ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7541 static Lisp_Object Vcode_conversion_reused_workbuf; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7542 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7543 /* 1 iff Vcode_conversion_reused_workbuf is already in use. */ |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7544 static int reused_workbuf_in_use; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7545 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7546 |
110983 | 7547 /* Return a working buffer of code conversion. MULTIBYTE specifies the |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7548 multibyteness of returning buffer. */ |
88365 | 7549 |
89863
428fc37b2ae6
Add many prototypes for static functions.
Kenichi Handa <handa@m17n.org>
parents:
89861
diff
changeset
|
7550 static Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
7551 make_conversion_work_buffer (int multibyte) |
88365 | 7552 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7553 Lisp_Object name, workbuf; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7554 struct buffer *current; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7555 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7556 if (reused_workbuf_in_use++) |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7557 { |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7558 name = Fgenerate_new_buffer_name (Vcode_conversion_workbuf_name, Qnil); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7559 workbuf = Fget_buffer_create (name); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7560 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7561 else |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7562 { |
99074
10cd979d05ca
(make_conversion_work_buffer): Check that Vcode_conversion_reused_workbuf
Noah Friedman <friedman@splode.com>
parents:
98992
diff
changeset
|
7563 if (NILP (Fbuffer_live_p (Vcode_conversion_reused_workbuf))) |
98186
1cfa973fde14
(make_conversion_work_buffer): Avoid calling
Kenichi Handa <handa@m17n.org>
parents:
96571
diff
changeset
|
7564 Vcode_conversion_reused_workbuf |
1cfa973fde14
(make_conversion_work_buffer): Avoid calling
Kenichi Handa <handa@m17n.org>
parents:
96571
diff
changeset
|
7565 = Fget_buffer_create (Vcode_conversion_workbuf_name); |
1cfa973fde14
(make_conversion_work_buffer): Avoid calling
Kenichi Handa <handa@m17n.org>
parents:
96571
diff
changeset
|
7566 workbuf = Vcode_conversion_reused_workbuf; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7567 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7568 current = current_buffer; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7569 set_buffer_internal (XBUFFER (workbuf)); |
100262
46114a72fb0e
(make_conversion_work_buffer): Disable buffer modification hooks in
Chong Yidong <cyd@stupidchicken.com>
parents:
100176
diff
changeset
|
7570 /* We can't allow modification hooks to run in the work buffer. For |
46114a72fb0e
(make_conversion_work_buffer): Disable buffer modification hooks in
Chong Yidong <cyd@stupidchicken.com>
parents:
100176
diff
changeset
|
7571 instance, directory_files_internal assumes that file decoding |
46114a72fb0e
(make_conversion_work_buffer): Disable buffer modification hooks in
Chong Yidong <cyd@stupidchicken.com>
parents:
100176
diff
changeset
|
7572 doesn't compile new regexps. */ |
46114a72fb0e
(make_conversion_work_buffer): Disable buffer modification hooks in
Chong Yidong <cyd@stupidchicken.com>
parents:
100176
diff
changeset
|
7573 Fset (Fmake_local_variable (Qinhibit_modification_hooks), Qt); |
93877
62d97ebb13a9
* coding.c (detect_coding_emacs_mule)
Michael Albinus <michael.albinus@gmx.de>
parents:
93595
diff
changeset
|
7574 Ferase_buffer (); |
88365 | 7575 current_buffer->undo_list = Qt; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7576 current_buffer->enable_multibyte_characters = multibyte ? Qt : Qnil; |
88365 | 7577 set_buffer_internal (current); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7578 return workbuf; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7579 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7580 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7581 |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7582 static Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
7583 code_conversion_restore (Lisp_Object arg) |
26067
f54ca66e2571
(code_convert_string): Add record_unwind_protect to
Kenichi Handa <handa@m17n.org>
parents:
25860
diff
changeset
|
7584 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7585 Lisp_Object current, workbuf; |
90263
80fb4c061e99
(code_conversion_restore): GCPRO arg.
Kenichi Handa <handa@m17n.org>
parents:
90261
diff
changeset
|
7586 struct gcpro gcpro1; |
80fb4c061e99
(code_conversion_restore): GCPRO arg.
Kenichi Handa <handa@m17n.org>
parents:
90261
diff
changeset
|
7587 |
80fb4c061e99
(code_conversion_restore): GCPRO arg.
Kenichi Handa <handa@m17n.org>
parents:
90261
diff
changeset
|
7588 GCPRO1 (arg); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7589 current = XCAR (arg); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7590 workbuf = XCDR (arg); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7591 if (! NILP (workbuf)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7592 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7593 if (EQ (workbuf, Vcode_conversion_reused_workbuf)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7594 reused_workbuf_in_use = 0; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7595 else if (! NILP (Fbuffer_live_p (workbuf))) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7596 Fkill_buffer (workbuf); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7597 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7598 set_buffer_internal (XBUFFER (current)); |
90263
80fb4c061e99
(code_conversion_restore): GCPRO arg.
Kenichi Handa <handa@m17n.org>
parents:
90261
diff
changeset
|
7599 UNGCPRO; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7600 return Qnil; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7601 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7602 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7603 Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
7604 code_conversion_save (int with_work_buf, int multibyte) |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7605 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7606 Lisp_Object workbuf = Qnil; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7607 |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7608 if (with_work_buf) |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7609 workbuf = make_conversion_work_buffer (multibyte); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7610 record_unwind_protect (code_conversion_restore, |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7611 Fcons (Fcurrent_buffer (), workbuf)); |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7612 return workbuf; |
17052 | 7613 } |
7614 | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7615 int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7616 decode_coding_gap (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7617 EMACS_INT chars, EMACS_INT bytes) |
88365 | 7618 { |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
7619 int count = SPECPDL_INDEX (); |
89448
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7620 Lisp_Object attrs; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7621 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7622 code_conversion_save (0, 0); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7623 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7624 coding->src_object = Fcurrent_buffer (); |
88365 | 7625 coding->src_chars = chars; |
7626 coding->src_bytes = bytes; | |
7627 coding->src_pos = -chars; | |
7628 coding->src_pos_byte = -bytes; | |
7629 coding->src_multibyte = chars < bytes; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7630 coding->dst_object = coding->src_object; |
88365 | 7631 coding->dst_pos = PT; |
7632 coding->dst_pos_byte = PT_BYTE; | |
88443
6b86cf30a0b9
(produce_chars): Set the variable `multibytep' correctly.
Kenichi Handa <handa@m17n.org>
parents:
88438
diff
changeset
|
7633 coding->dst_multibyte = ! NILP (current_buffer->enable_multibyte_characters); |
88365 | 7634 |
7635 if (CODING_REQUIRE_DETECTION (coding)) | |
7636 detect_coding (coding); | |
89483 | 7637 |
90350
60eaefb08cf7
(DECODE_COMPOSITION_START): If the source is short, set
Kenichi Handa <handa@m17n.org>
parents:
90346
diff
changeset
|
7638 coding->mode |= CODING_MODE_LAST_BLOCK; |
90772
b15334b4a9c3
(coding_alloc_by_making_gap): New arg offset.
Kenichi Handa <handa@m17n.org>
parents:
90737
diff
changeset
|
7639 current_buffer->text->inhibit_shrinking = 1; |
88365 | 7640 decode_coding (coding); |
90772
b15334b4a9c3
(coding_alloc_by_making_gap): New arg offset.
Kenichi Handa <handa@m17n.org>
parents:
90737
diff
changeset
|
7641 current_buffer->text->inhibit_shrinking = 0; |
88365 | 7642 |
89448
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7643 attrs = CODING_ID_ATTRS (coding->id); |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7644 if (! NILP (CODING_ATTR_POST_READ (attrs))) |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7645 { |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7646 EMACS_INT prev_Z = Z, prev_Z_BYTE = Z_BYTE; |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7647 Lisp_Object val; |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7648 |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7649 TEMP_SET_PT_BOTH (coding->dst_pos, coding->dst_pos_byte); |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7650 val = call1 (CODING_ATTR_POST_READ (attrs), |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7651 make_number (coding->produced_char)); |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7652 CHECK_NATNUM (val); |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7653 coding->produced_char += Z - prev_Z; |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7654 coding->produced += Z_BYTE - prev_Z_BYTE; |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7655 } |
de8b460070cc
(setup_coding_system): If coding has
Kenichi Handa <handa@m17n.org>
parents:
89446
diff
changeset
|
7656 |
88365 | 7657 unbind_to (count, Qnil); |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
7658 return coding->result; |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7659 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7660 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7661 int |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7662 encode_coding_gap (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7663 EMACS_INT chars, EMACS_INT bytes) |
26847 | 7664 { |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
7665 int count = SPECPDL_INDEX (); |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7666 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7667 code_conversion_save (0, 0); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7668 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7669 coding->src_object = Fcurrent_buffer (); |
88365 | 7670 coding->src_chars = chars; |
7671 coding->src_bytes = bytes; | |
7672 coding->src_pos = -chars; | |
7673 coding->src_pos_byte = -bytes; | |
7674 coding->src_multibyte = chars < bytes; | |
7675 coding->dst_object = coding->src_object; | |
7676 coding->dst_pos = PT; | |
7677 coding->dst_pos_byte = PT_BYTE; | |
7678 | |
7679 encode_coding (coding); | |
7680 | |
7681 unbind_to (count, Qnil); | |
7682 return coding->result; | |
26847 | 7683 } |
7684 | |
88365 | 7685 |
7686 /* Decode the text in the range FROM/FROM_BYTE and TO/TO_BYTE in | |
7687 SRC_OBJECT into DST_OBJECT by coding context CODING. | |
7688 | |
7689 SRC_OBJECT is a buffer, a string, or Qnil. | |
7690 | |
7691 If it is a buffer, the text is at point of the buffer. FROM and TO | |
7692 are positions in the buffer. | |
7693 | |
7694 If it is a string, the text is at the beginning of the string. | |
7695 FROM and TO are indices to the string. | |
7696 | |
7697 If it is nil, the text is at coding->source. FROM and TO are | |
7698 indices to coding->source. | |
7699 | |
7700 DST_OBJECT is a buffer, Qt, or Qnil. | |
7701 | |
7702 If it is a buffer, the decoded text is inserted at point of the | |
7703 buffer. If the buffer is the same as SRC_OBJECT, the source text | |
7704 is deleted. | |
7705 | |
7706 If it is Qt, a string is made from the decoded text, and | |
7707 set in CODING->dst_object. | |
7708 | |
7709 If it is Qnil, the decoded text is stored at CODING->destination. | |
89418
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
7710 The caller must allocate CODING->dst_bytes bytes at |
88365 | 7711 CODING->destination by xmalloc. If the decoded text is longer than |
7712 CODING->dst_bytes, CODING->destination is relocated by xrealloc. | |
7713 */ | |
26847 | 7714 |
7715 void | |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7716 decode_coding_object (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7717 Lisp_Object src_object, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7718 EMACS_INT from, EMACS_INT from_byte, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7719 EMACS_INT to, EMACS_INT to_byte, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7720 Lisp_Object dst_object) |
26847 | 7721 { |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
7722 int count = SPECPDL_INDEX (); |
88365 | 7723 unsigned char *destination; |
7724 EMACS_INT dst_bytes; | |
7725 EMACS_INT chars = to - from; | |
7726 EMACS_INT bytes = to_byte - from_byte; | |
7727 Lisp_Object attrs; | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7728 int saved_pt = -1, saved_pt_byte; |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7729 int need_marker_adjustment = 0; |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7730 Lisp_Object old_deactivate_mark; |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7731 |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7732 old_deactivate_mark = Vdeactivate_mark; |
88365 | 7733 |
7734 if (NILP (dst_object)) | |
7735 { | |
7736 destination = coding->destination; | |
7737 dst_bytes = coding->dst_bytes; | |
7738 } | |
7739 | |
7740 coding->src_object = src_object; | |
7741 coding->src_chars = chars; | |
7742 coding->src_bytes = bytes; | |
7743 coding->src_multibyte = chars < bytes; | |
7744 | |
7745 if (STRINGP (src_object)) | |
7746 { | |
7747 coding->src_pos = from; | |
7748 coding->src_pos_byte = from_byte; | |
7749 } | |
7750 else if (BUFFERP (src_object)) | |
7751 { | |
7752 set_buffer_internal (XBUFFER (src_object)); | |
7753 if (from != GPT) | |
7754 move_gap_both (from, from_byte); | |
7755 if (EQ (src_object, dst_object)) | |
26847 | 7756 { |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7757 struct Lisp_Marker *tail; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7758 |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7759 for (tail = BUF_MARKERS (current_buffer); tail; tail = tail->next) |
26847 | 7760 { |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7761 tail->need_adjustment |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7762 = tail->charpos == (tail->insertion_type ? from : to); |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7763 need_marker_adjustment |= tail->need_adjustment; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7764 } |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7765 saved_pt = PT, saved_pt_byte = PT_BYTE; |
88365 | 7766 TEMP_SET_PT_BOTH (from, from_byte); |
92458
5f5f07a5c076
(decode_coding_object): Inhibit gap shrinking while
Andreas Schwab <schwab@suse.de>
parents:
92406
diff
changeset
|
7767 current_buffer->text->inhibit_shrinking = 1; |
88365 | 7768 del_range_both (from, from_byte, to, to_byte, 1); |
7769 coding->src_pos = -chars; | |
7770 coding->src_pos_byte = -bytes; | |
20931
068eb408c911
(decode_coding_iso2022): Update coding->fake_multibyte.
Kenichi Handa <handa@m17n.org>
parents:
20803
diff
changeset
|
7771 } |
42661
e85e4d9494b1
(code_convert_region): Don't copy old text if undo disabled.
Richard M. Stallman <rms@gnu.org>
parents:
42105
diff
changeset
|
7772 else |
e85e4d9494b1
(code_convert_region): Don't copy old text if undo disabled.
Richard M. Stallman <rms@gnu.org>
parents:
42105
diff
changeset
|
7773 { |
88365 | 7774 coding->src_pos = from; |
7775 coding->src_pos_byte = from_byte; | |
29985
c17e78d8c720
(code_convert_region): Even if the length of text is
Kenichi Handa <handa@m17n.org>
parents:
29932
diff
changeset
|
7776 } |
88365 | 7777 } |
7778 | |
7779 if (CODING_REQUIRE_DETECTION (coding)) | |
7780 detect_coding (coding); | |
7781 attrs = CODING_ID_ATTRS (coding->id); | |
7782 | |
89418
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
7783 if (EQ (dst_object, Qt) |
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
7784 || (! NILP (CODING_ATTR_POST_READ (attrs)) |
a9c2b3712863
(coding_set_source): Fix for the case that the current
Kenichi Handa <handa@m17n.org>
parents:
89404
diff
changeset
|
7785 && NILP (dst_object))) |
88365 | 7786 { |
93321
c3fe9ef79b56
(decode_coding_object): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93197
diff
changeset
|
7787 coding->dst_multibyte = !CODING_FOR_UNIBYTE (coding); |
c3fe9ef79b56
(decode_coding_object): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93197
diff
changeset
|
7788 coding->dst_object = code_conversion_save (1, coding->dst_multibyte); |
88365 | 7789 coding->dst_pos = BEG; |
7790 coding->dst_pos_byte = BEG_BYTE; | |
7791 } | |
7792 else if (BUFFERP (dst_object)) | |
7793 { | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7794 code_conversion_save (0, 0); |
88365 | 7795 coding->dst_object = dst_object; |
7796 coding->dst_pos = BUF_PT (XBUFFER (dst_object)); | |
7797 coding->dst_pos_byte = BUF_PT_BYTE (XBUFFER (dst_object)); | |
7798 coding->dst_multibyte | |
7799 = ! NILP (XBUFFER (dst_object)->enable_multibyte_characters); | |
7800 } | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
7801 else |
29172
46ad5a027334
(run_pre_post_conversion_on_str): Set point to the
Kenichi Handa <handa@m17n.org>
parents:
29093
diff
changeset
|
7802 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7803 code_conversion_save (0, 0); |
88365 | 7804 coding->dst_object = Qnil; |
93322
3b82aab9d8fc
(decode_coding_object): Revert part of last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93321
diff
changeset
|
7805 /* Most callers presume this will return a multibyte result, and they |
3b82aab9d8fc
(decode_coding_object): Revert part of last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93321
diff
changeset
|
7806 won't use `binary' or `raw-text' anyway, so let's not worry about |
3b82aab9d8fc
(decode_coding_object): Revert part of last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93321
diff
changeset
|
7807 CODING_FOR_UNIBYTE. */ |
93323
06e93ffa2e9f
(decode_coding_object): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93322
diff
changeset
|
7808 coding->dst_multibyte = 1; |
88365 | 7809 } |
7810 | |
7811 decode_coding (coding); | |
7812 | |
7813 if (BUFFERP (coding->dst_object)) | |
7814 set_buffer_internal (XBUFFER (coding->dst_object)); | |
7815 | |
7816 if (! NILP (CODING_ATTR_POST_READ (attrs))) | |
7817 { | |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7818 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4, gcpro5; |
88365 | 7819 EMACS_INT prev_Z = Z, prev_Z_BYTE = Z_BYTE; |
7820 Lisp_Object val; | |
7821 | |
88506
a7f0d13affa5
(decode_coding_object): Move point to coding->dst_pos before
Kenichi Handa <handa@m17n.org>
parents:
88497
diff
changeset
|
7822 TEMP_SET_PT_BOTH (coding->dst_pos, coding->dst_pos_byte); |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7823 GCPRO5 (coding->src_object, coding->dst_object, src_object, dst_object, |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7824 old_deactivate_mark); |
90131
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7825 val = safe_call1 (CODING_ATTR_POST_READ (attrs), |
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7826 make_number (coding->produced_char)); |
88365 | 7827 UNGCPRO; |
7828 CHECK_NATNUM (val); | |
7829 coding->produced_char += Z - prev_Z; | |
7830 coding->produced += Z_BYTE - prev_Z_BYTE; | |
7831 } | |
7832 | |
7833 if (EQ (dst_object, Qt)) | |
7834 { | |
7835 coding->dst_object = Fbuffer_string (); | |
7836 } | |
7837 else if (NILP (dst_object) && BUFFERP (coding->dst_object)) | |
7838 { | |
7839 set_buffer_internal (XBUFFER (coding->dst_object)); | |
7840 if (dst_bytes < coding->produced) | |
42105
09cc243e2d14
(code_convert_region): Update coding->cmp_data->char_offset
Richard M. Stallman <rms@gnu.org>
parents:
42104
diff
changeset
|
7841 { |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7842 destination = xrealloc (destination, coding->produced); |
88365 | 7843 if (! destination) |
26847 | 7844 { |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7845 record_conversion_result (coding, |
107174
e98bd64897e0
Fix handling of CODING_RESULT_INSUFFICIENT_DST.
Kenichi Handa <handa@m17n.org>
parents:
107171
diff
changeset
|
7846 CODING_RESULT_INSUFFICIENT_MEM); |
88365 | 7847 unbind_to (count, Qnil); |
7848 return; | |
26847 | 7849 } |
88365 | 7850 if (BEGV < GPT && GPT < BEGV + coding->produced_char) |
7851 move_gap_both (BEGV, BEGV_BYTE); | |
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109159
diff
changeset
|
7852 memcpy (destination, BEGV_ADDR, coding->produced); |
88365 | 7853 coding->destination = destination; |
23279
ca159e828a68
(ccl_coding_driver): If ccl_driver is interrupted by a
Kenichi Handa <handa@m17n.org>
parents:
23258
diff
changeset
|
7854 } |
88365 | 7855 } |
7856 | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7857 if (saved_pt >= 0) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7858 { |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7859 /* This is the case of: |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7860 (BUFFERP (src_object) && EQ (src_object, dst_object)) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7861 As we have moved PT while replacing the original buffer |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7862 contents, we must recover it now. */ |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7863 set_buffer_internal (XBUFFER (src_object)); |
92458
5f5f07a5c076
(decode_coding_object): Inhibit gap shrinking while
Andreas Schwab <schwab@suse.de>
parents:
92406
diff
changeset
|
7864 current_buffer->text->inhibit_shrinking = 0; |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7865 if (saved_pt < from) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7866 TEMP_SET_PT_BOTH (saved_pt, saved_pt_byte); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7867 else if (saved_pt < from + chars) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7868 TEMP_SET_PT_BOTH (from, from_byte); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7869 else if (! NILP (current_buffer->enable_multibyte_characters)) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7870 TEMP_SET_PT_BOTH (saved_pt + (coding->produced_char - chars), |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7871 saved_pt_byte + (coding->produced - bytes)); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7872 else |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7873 TEMP_SET_PT_BOTH (saved_pt + (coding->produced - bytes), |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7874 saved_pt_byte + (coding->produced - bytes)); |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7875 |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7876 if (need_marker_adjustment) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7877 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7878 struct Lisp_Marker *tail; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7879 |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7880 for (tail = BUF_MARKERS (current_buffer); tail; tail = tail->next) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7881 if (tail->need_adjustment) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7882 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7883 tail->need_adjustment = 0; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7884 if (tail->insertion_type) |
26847 | 7885 { |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7886 tail->bytepos = from_byte; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7887 tail->charpos = from; |
26847 | 7888 } |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7889 else |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7890 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7891 tail->bytepos = from_byte + coding->produced; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7892 tail->charpos |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7893 = (NILP (current_buffer->enable_multibyte_characters) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7894 ? tail->bytepos : from + coding->produced_char); |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7895 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7896 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7897 } |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7898 } |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7899 |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7900 Vdeactivate_mark = old_deactivate_mark; |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
7901 unbind_to (count, coding->dst_object); |
88365 | 7902 } |
7903 | |
26847 | 7904 |
29275
b4ea9178e480
(DECODE_COMPOSITION_START): If coding->cmp_data is not
Kenichi Handa <handa@m17n.org>
parents:
29247
diff
changeset
|
7905 void |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7906 encode_coding_object (struct coding_system *coding, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7907 Lisp_Object src_object, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7908 EMACS_INT from, EMACS_INT from_byte, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7909 EMACS_INT to, EMACS_INT to_byte, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
7910 Lisp_Object dst_object) |
88365 | 7911 { |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
7912 int count = SPECPDL_INDEX (); |
88365 | 7913 EMACS_INT chars = to - from; |
7914 EMACS_INT bytes = to_byte - from_byte; | |
7915 Lisp_Object attrs; | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7916 int saved_pt = -1, saved_pt_byte; |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7917 int need_marker_adjustment = 0; |
90231
8be9e4c6d687
(encode_coding_object): If a pre-write-conversion
Kenichi Handa <handa@m17n.org>
parents:
90224
diff
changeset
|
7918 int kill_src_buffer = 0; |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7919 Lisp_Object old_deactivate_mark; |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7920 |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7921 old_deactivate_mark = Vdeactivate_mark; |
88365 | 7922 |
7923 coding->src_object = src_object; | |
7924 coding->src_chars = chars; | |
7925 coding->src_bytes = bytes; | |
7926 coding->src_multibyte = chars < bytes; | |
7927 | |
7928 attrs = CODING_ID_ATTRS (coding->id); | |
7929 | |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7930 if (EQ (src_object, dst_object)) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7931 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7932 struct Lisp_Marker *tail; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7933 |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7934 for (tail = BUF_MARKERS (current_buffer); tail; tail = tail->next) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7935 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7936 tail->need_adjustment |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7937 = tail->charpos == (tail->insertion_type ? from : to); |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7938 need_marker_adjustment |= tail->need_adjustment; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7939 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7940 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
7941 |
88365 | 7942 if (! NILP (CODING_ATTR_PRE_WRITE (attrs))) |
21062
839b22ad1e42
(code_convert_region): Handle the case that codes
Kenichi Handa <handa@m17n.org>
parents:
20999
diff
changeset
|
7943 { |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7944 coding->src_object = code_conversion_save (1, coding->src_multibyte); |
88365 | 7945 set_buffer_internal (XBUFFER (coding->src_object)); |
7946 if (STRINGP (src_object)) | |
7947 insert_from_string (src_object, from, from_byte, chars, bytes, 0); | |
7948 else if (BUFFERP (src_object)) | |
7949 insert_from_buffer (XBUFFER (src_object), from, chars, 0); | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
7950 else |
88365 | 7951 insert_1_both (coding->source + from, chars, bytes, 0, 0, 0); |
7952 | |
7953 if (EQ (src_object, dst_object)) | |
7954 { | |
7955 set_buffer_internal (XBUFFER (src_object)); | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7956 saved_pt = PT, saved_pt_byte = PT_BYTE; |
88365 | 7957 del_range_both (from, from_byte, to, to_byte, 1); |
7958 set_buffer_internal (XBUFFER (coding->src_object)); | |
7959 } | |
7960 | |
90131
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7961 { |
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7962 Lisp_Object args[3]; |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7963 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4, gcpro5; |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7964 |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7965 GCPRO5 (coding->src_object, coding->dst_object, src_object, dst_object, |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7966 old_deactivate_mark); |
90131
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7967 args[0] = CODING_ATTR_PRE_WRITE (attrs); |
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7968 args[1] = make_number (BEG); |
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7969 args[2] = make_number (Z); |
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7970 safe_call (3, args); |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
7971 UNGCPRO; |
90131
503a3c779486
(decode_coding_object): Use safe_call1 instead of call1.
Kenichi Handa <handa@m17n.org>
parents:
90127
diff
changeset
|
7972 } |
90231
8be9e4c6d687
(encode_coding_object): If a pre-write-conversion
Kenichi Handa <handa@m17n.org>
parents:
90224
diff
changeset
|
7973 if (XBUFFER (coding->src_object) != current_buffer) |
8be9e4c6d687
(encode_coding_object): If a pre-write-conversion
Kenichi Handa <handa@m17n.org>
parents:
90224
diff
changeset
|
7974 kill_src_buffer = 1; |
88510
d266b8fb8761
(encode_coding_object): Give correct arguments ot
Kenichi Handa <handa@m17n.org>
parents:
88506
diff
changeset
|
7975 coding->src_object = Fcurrent_buffer (); |
88365 | 7976 if (BEG != GPT) |
7977 move_gap_both (BEG, BEG_BYTE); | |
7978 coding->src_chars = Z - BEG; | |
7979 coding->src_bytes = Z_BYTE - BEG_BYTE; | |
7980 coding->src_pos = BEG; | |
7981 coding->src_pos_byte = BEG_BYTE; | |
7982 coding->src_multibyte = Z < Z_BYTE; | |
7983 } | |
7984 else if (STRINGP (src_object)) | |
7985 { | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7986 code_conversion_save (0, 0); |
88365 | 7987 coding->src_pos = from; |
7988 coding->src_pos_byte = from_byte; | |
7989 } | |
7990 else if (BUFFERP (src_object)) | |
7991 { | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
7992 code_conversion_save (0, 0); |
88365 | 7993 set_buffer_internal (XBUFFER (src_object)); |
7994 if (EQ (src_object, dst_object)) | |
7995 { | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
7996 saved_pt = PT, saved_pt_byte = PT_BYTE; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7997 coding->src_object = del_range_1 (from, to, 1, 1); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7998 coding->src_pos = 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
7999 coding->src_pos_byte = 0; |
88365 | 8000 } |
23514
7bad909cd6f1
(setup_coding_system): Fix setting up
Kenichi Handa <handa@m17n.org>
parents:
23475
diff
changeset
|
8001 else |
42105
09cc243e2d14
(code_convert_region): Update coding->cmp_data->char_offset
Richard M. Stallman <rms@gnu.org>
parents:
42104
diff
changeset
|
8002 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8003 if (from < GPT && to >= GPT) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8004 move_gap_both (from, from_byte); |
88365 | 8005 coding->src_pos = from; |
8006 coding->src_pos_byte = from_byte; | |
8007 } | |
64308
93129de4b8a4
(code_convert_region_unwind): ARG is changed to a cons.
Kenichi Handa <handa@m17n.org>
parents:
64251
diff
changeset
|
8008 } |
93129de4b8a4
(code_convert_region_unwind): ARG is changed to a cons.
Kenichi Handa <handa@m17n.org>
parents:
64251
diff
changeset
|
8009 else |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8010 code_conversion_save (0, 0); |
88365 | 8011 |
8012 if (BUFFERP (dst_object)) | |
8013 { | |
8014 coding->dst_object = dst_object; | |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8015 if (EQ (src_object, dst_object)) |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8016 { |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8017 coding->dst_pos = from; |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8018 coding->dst_pos_byte = from_byte; |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8019 } |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8020 else |
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8021 { |
95353
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8022 struct buffer *current = current_buffer; |
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8023 |
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8024 set_buffer_temp (XBUFFER (dst_object)); |
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8025 coding->dst_pos = PT; |
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8026 coding->dst_pos_byte = PT_BYTE; |
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8027 move_gap_both (coding->dst_pos, coding->dst_pos_byte); |
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
8028 set_buffer_temp (current); |
89042
2b9f8973f240
(coding_set_destination): Fix coding->destination for
Kenichi Handa <handa@m17n.org>
parents:
88977
diff
changeset
|
8029 } |
88365 | 8030 coding->dst_multibyte |
8031 = ! NILP (XBUFFER (dst_object)->enable_multibyte_characters); | |
8032 } | |
8033 else if (EQ (dst_object, Qt)) | |
8034 { | |
8035 coding->dst_object = Qnil; | |
8036 coding->dst_bytes = coding->src_chars; | |
88510
d266b8fb8761
(encode_coding_object): Give correct arguments ot
Kenichi Handa <handa@m17n.org>
parents:
88506
diff
changeset
|
8037 if (coding->dst_bytes == 0) |
d266b8fb8761
(encode_coding_object): Give correct arguments ot
Kenichi Handa <handa@m17n.org>
parents:
88506
diff
changeset
|
8038 coding->dst_bytes = 1; |
d266b8fb8761
(encode_coding_object): Give correct arguments ot
Kenichi Handa <handa@m17n.org>
parents:
88506
diff
changeset
|
8039 coding->destination = (unsigned char *) xmalloc (coding->dst_bytes); |
88365 | 8040 coding->dst_multibyte = 0; |
65506
f376635f5061
(code_convert_region_unwind): Argument format changed.
Kenichi Handa <handa@m17n.org>
parents:
64770
diff
changeset
|
8041 } |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
8042 else |
29172
46ad5a027334
(run_pre_post_conversion_on_str): Set point to the
Kenichi Handa <handa@m17n.org>
parents:
29093
diff
changeset
|
8043 { |
88365 | 8044 coding->dst_object = Qnil; |
8045 coding->dst_multibyte = 0; | |
8046 } | |
8047 | |
8048 encode_coding (coding); | |
8049 | |
8050 if (EQ (dst_object, Qt)) | |
8051 { | |
8052 if (BUFFERP (coding->dst_object)) | |
8053 coding->dst_object = Fbuffer_string (); | |
23514
7bad909cd6f1
(setup_coding_system): Fix setting up
Kenichi Handa <handa@m17n.org>
parents:
23475
diff
changeset
|
8054 else |
88365 | 8055 { |
8056 coding->dst_object | |
8057 = make_unibyte_string ((char *) coding->destination, | |
8058 coding->produced); | |
8059 xfree (coding->destination); | |
8060 } | |
8061 } | |
8062 | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8063 if (saved_pt >= 0) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8064 { |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8065 /* This is the case of: |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8066 (BUFFERP (src_object) && EQ (src_object, dst_object)) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8067 As we have moved PT while replacing the original buffer |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8068 contents, we must recover it now. */ |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8069 set_buffer_internal (XBUFFER (src_object)); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8070 if (saved_pt < from) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8071 TEMP_SET_PT_BOTH (saved_pt, saved_pt_byte); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8072 else if (saved_pt < from + chars) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8073 TEMP_SET_PT_BOTH (from, from_byte); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8074 else if (! NILP (current_buffer->enable_multibyte_characters)) |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8075 TEMP_SET_PT_BOTH (saved_pt + (coding->produced_char - chars), |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8076 saved_pt_byte + (coding->produced - bytes)); |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8077 else |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8078 TEMP_SET_PT_BOTH (saved_pt + (coding->produced - bytes), |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8079 saved_pt_byte + (coding->produced - bytes)); |
91344
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8080 |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8081 if (need_marker_adjustment) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8082 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8083 struct Lisp_Marker *tail; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8084 |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8085 for (tail = BUF_MARKERS (current_buffer); tail; tail = tail->next) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8086 if (tail->need_adjustment) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8087 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8088 tail->need_adjustment = 0; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8089 if (tail->insertion_type) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8090 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8091 tail->bytepos = from_byte; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8092 tail->charpos = from; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8093 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8094 else |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8095 { |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8096 tail->bytepos = from_byte + coding->produced; |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8097 tail->charpos |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8098 = (NILP (current_buffer->enable_multibyte_characters) |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8099 ? tail->bytepos : from + coding->produced_char); |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8100 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8101 } |
56f3473b139e
(decode_coding_object): Adjuste marker positions after
Kenichi Handa <handa@m17n.org>
parents:
91327
diff
changeset
|
8102 } |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8103 } |
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
8104 |
90231
8be9e4c6d687
(encode_coding_object): If a pre-write-conversion
Kenichi Handa <handa@m17n.org>
parents:
90224
diff
changeset
|
8105 if (kill_src_buffer) |
8be9e4c6d687
(encode_coding_object): If a pre-write-conversion
Kenichi Handa <handa@m17n.org>
parents:
90224
diff
changeset
|
8106 Fkill_buffer (coding->src_object); |
91838
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
8107 |
7bed61cbed0c
(decode_coding_object, encode_coding_object): Preserve
Kenichi Handa <handa@m17n.org>
parents:
91807
diff
changeset
|
8108 Vdeactivate_mark = old_deactivate_mark; |
88365 | 8109 unbind_to (count, Qnil); |
58637
ff8a37b5299b
(Vcode_conversion_workbuf_name): New variable.
Kenichi Handa <handa@m17n.org>
parents:
58502
diff
changeset
|
8110 } |
ff8a37b5299b
(Vcode_conversion_workbuf_name): New variable.
Kenichi Handa <handa@m17n.org>
parents:
58502
diff
changeset
|
8111 |
ff8a37b5299b
(Vcode_conversion_workbuf_name): New variable.
Kenichi Handa <handa@m17n.org>
parents:
58502
diff
changeset
|
8112 |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
8113 Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
8114 preferred_coding_system (void) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8115 { |
88365 | 8116 int id = coding_categories[coding_priorities[0]].id; |
8117 | |
8118 return CODING_ID_NAME (id); | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8119 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8120 |
17052 | 8121 |
8122 #ifdef emacs | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
8123 /*** 8. Emacs Lisp library functions ***/ |
17052 | 8124 |
8125 DEFUN ("coding-system-p", Fcoding_system_p, Scoding_system_p, 1, 1, 0, | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8126 doc: /* Return t if OBJECT is nil or a coding-system. |
88365 | 8127 See the documentation of `define-coding-system' for information |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8128 about coding-system objects. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8129 (Lisp_Object object) |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8130 { |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8131 if (NILP (object) |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8132 || CODING_SYSTEM_ID (object) >= 0) |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
8133 return Qt; |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8134 if (! SYMBOLP (object) |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8135 || NILP (Fget (object, Qcoding_system_define_form))) |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
8136 return Qnil; |
90272
f1df126ec7de
Sync to HEAD for handling autoload-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
90263
diff
changeset
|
8137 return Qt; |
17052 | 8138 } |
8139 | |
17717
4891aaecc5cc
(Fread_coding_system, Fread_non_nil_coding_system):
Richard M. Stallman <rms@gnu.org>
parents:
17485
diff
changeset
|
8140 DEFUN ("read-non-nil-coding-system", Fread_non_nil_coding_system, |
4891aaecc5cc
(Fread_coding_system, Fread_non_nil_coding_system):
Richard M. Stallman <rms@gnu.org>
parents:
17485
diff
changeset
|
8141 Sread_non_nil_coding_system, 1, 1, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8142 doc: /* Read a coding system from the minibuffer, prompting with string PROMPT. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8143 (Lisp_Object prompt) |
17052 | 8144 { |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
8145 Lisp_Object val; |
17717
4891aaecc5cc
(Fread_coding_system, Fread_non_nil_coding_system):
Richard M. Stallman <rms@gnu.org>
parents:
17485
diff
changeset
|
8146 do |
4891aaecc5cc
(Fread_coding_system, Fread_non_nil_coding_system):
Richard M. Stallman <rms@gnu.org>
parents:
17485
diff
changeset
|
8147 { |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
8148 val = Fcompleting_read (prompt, Vcoding_system_alist, Qnil, |
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
8149 Qt, Qnil, Qcoding_system_history, Qnil, Qnil); |
17717
4891aaecc5cc
(Fread_coding_system, Fread_non_nil_coding_system):
Richard M. Stallman <rms@gnu.org>
parents:
17485
diff
changeset
|
8150 } |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46293
diff
changeset
|
8151 while (SCHARS (val) == 0); |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
8152 return (Fintern (val, Qnil)); |
17052 | 8153 } |
8154 | |
19758
49a1662b68dd
(Fread_coding_system): New optional arg DEFAULT_CODING_SYSTEM.
Richard M. Stallman <rms@gnu.org>
parents:
19750
diff
changeset
|
8155 DEFUN ("read-coding-system", Fread_coding_system, Sread_coding_system, 1, 2, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8156 doc: /* Read a coding system from the minibuffer, prompting with string PROMPT. |
79107
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8157 If the user enters null input, return second argument DEFAULT-CODING-SYSTEM. |
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8158 Ignores case when completing coding systems (all Emacs coding systems |
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8159 are lower-case). */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8160 (Lisp_Object prompt, Lisp_Object default_coding_system) |
17052 | 8161 { |
19747
bed06df9cbc5
(setup_coding_system, Ffind_operation_coding_system)
Richard M. Stallman <rms@gnu.org>
parents:
19743
diff
changeset
|
8162 Lisp_Object val; |
79107
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8163 int count = SPECPDL_INDEX (); |
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8164 |
19758
49a1662b68dd
(Fread_coding_system): New optional arg DEFAULT_CODING_SYSTEM.
Richard M. Stallman <rms@gnu.org>
parents:
19750
diff
changeset
|
8165 if (SYMBOLP (default_coding_system)) |
45396
cab845213388
* coding.c (Fread_coding_system, code_convert_region1)
Ken Raeburn <raeburn@raeburn.org>
parents:
45239
diff
changeset
|
8166 default_coding_system = SYMBOL_NAME (default_coding_system); |
79107
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8167 specbind (Qcompletion_ignore_case, Qt); |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
8168 val = Fcompleting_read (prompt, Vcoding_system_alist, Qnil, |
19758
49a1662b68dd
(Fread_coding_system): New optional arg DEFAULT_CODING_SYSTEM.
Richard M. Stallman <rms@gnu.org>
parents:
19750
diff
changeset
|
8169 Qt, Qnil, Qcoding_system_history, |
49a1662b68dd
(Fread_coding_system): New optional arg DEFAULT_CODING_SYSTEM.
Richard M. Stallman <rms@gnu.org>
parents:
19750
diff
changeset
|
8170 default_coding_system, Qnil); |
79107
cce707ee192e
(Qcompletion_ignore_case): New external Lisp_Object.
Glenn Morris <rgm@gnu.org>
parents:
78313
diff
changeset
|
8171 unbind_to (count, Qnil); |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46293
diff
changeset
|
8172 return (SCHARS (val) == 0 ? Qnil : Fintern (val, Qnil)); |
17052 | 8173 } |
8174 | |
8175 DEFUN ("check-coding-system", Fcheck_coding_system, Scheck_coding_system, | |
8176 1, 1, 0, | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8177 doc: /* Check validity of CODING-SYSTEM. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8178 If valid, return CODING-SYSTEM, else signal a `coding-system-error' error. |
89892 | 8179 It is valid if it is nil or a symbol defined as a coding system by the |
8180 function `define-coding-system'. */) | |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8181 (Lisp_Object coding_system) |
17052 | 8182 { |
52794
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8183 Lisp_Object define_form; |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8184 |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8185 define_form = Fget (coding_system, Qcoding_system_define_form); |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8186 if (! NILP (define_form)) |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8187 { |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8188 Fput (coding_system, Qcoding_system_define_form, Qnil); |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8189 safe_eval (define_form); |
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
8190 } |
17052 | 8191 if (!NILP (Fcoding_system_p (coding_system))) |
8192 return coding_system; | |
71972
eaa3c19b94d2
(Fcheck_coding_system): Use xsignal1. Remove loop.
Kim F. Storm <storm@cua.dk>
parents:
71084
diff
changeset
|
8193 xsignal1 (Qcoding_system_error, coding_system); |
17052 | 8194 } |
88365 | 8195 |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
8196 |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8197 /* Detect how the bytes at SRC of length SRC_BYTES are encoded. If |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8198 HIGHEST is nonzero, return the coding system of the highest |
110983 | 8199 priority among the detected coding systems. Otherwise return a |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8200 list of detected coding systems sorted by their priorities. If |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8201 MULTIBYTEP is nonzero, it is assumed that the bytes are in correct |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8202 multibyte form but contains only ASCII and eight-bit chars. |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8203 Otherwise, the bytes are raw bytes. |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8204 |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8205 CODING-SYSTEM controls the detection as below: |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8206 |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8207 If it is nil, detect both text-format and eol-format. If the |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8208 text-format part of CODING-SYSTEM is already specified |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8209 (e.g. `iso-latin-1'), detect only eol-format. If the eol-format |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8210 part of CODING-SYSTEM is already specified (e.g. `undecided-unix'), |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8211 detect only text-format. */ |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8212 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8213 Lisp_Object |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8214 detect_coding_system (const unsigned char *src, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8215 EMACS_INT src_chars, EMACS_INT src_bytes, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8216 int highest, int multibytep, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8217 Lisp_Object coding_system) |
17052 | 8218 { |
89483 | 8219 const unsigned char *src_end = src + src_bytes; |
88365 | 8220 Lisp_Object attrs, eol_type; |
100135
0e17542db552
(detect_coding_system): Initialize utf_16_le_eol to -1, val to
Kenichi Handa <handa@m17n.org>
parents:
100133
diff
changeset
|
8221 Lisp_Object val = Qnil; |
88365 | 8222 struct coding_system coding; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8223 int id; |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8224 struct coding_detection_info detect_info; |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8225 enum coding_category base_category; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8226 int null_byte_found = 0, eight_bit_found = 0; |
88365 | 8227 |
8228 if (NILP (coding_system)) | |
8229 coding_system = Qundecided; | |
8230 setup_coding_system (coding_system, &coding); | |
8231 attrs = CODING_ID_ATTRS (coding.id); | |
8232 eol_type = CODING_ID_EOL_TYPE (coding.id); | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8233 coding_system = CODING_ATTR_BASE_NAME (attrs); |
88365 | 8234 |
8235 coding.source = src; | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8236 coding.src_chars = src_chars; |
88365 | 8237 coding.src_bytes = src_bytes; |
8238 coding.src_multibyte = multibytep; | |
8239 coding.consumed = 0; | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8240 coding.mode |= CODING_MODE_LAST_BLOCK; |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8241 coding.head_ascii = 0; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8242 |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8243 detect_info.checked = detect_info.found = detect_info.rejected = 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8244 |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8245 /* At first, detect text-format if necessary. */ |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8246 base_category = XINT (CODING_ATTR_CATEGORY (attrs)); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8247 if (base_category == coding_category_undecided) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8248 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8249 enum coding_category category; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8250 struct coding_system *this; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8251 int c, i; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8252 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8253 /* Skip all ASCII bytes except for a few ISO2022 controls. */ |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8254 for (; src < src_end; src++) |
17052 | 8255 { |
88365 | 8256 c = *src; |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8257 if (c & 0x80) |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8258 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8259 eight_bit_found = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8260 if (null_byte_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8261 break; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8262 } |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8263 else if (c < 0x20) |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8264 { |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8265 if ((c == ISO_CODE_ESC || c == ISO_CODE_SI || c == ISO_CODE_SO) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8266 && ! inhibit_iso_escape_detection |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8267 && ! detect_info.checked) |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8268 { |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8269 if (detect_coding_iso_2022 (&coding, &detect_info)) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8270 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8271 /* We have scanned the whole data. */ |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8272 if (! (detect_info.rejected & CATEGORY_MASK_ISO_7_ELSE)) |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8273 { |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8274 /* We didn't find an 8-bit code. We may |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8275 have found a null-byte, but it's very |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8276 rare that a binary file confirm to |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8277 ISO-2022. */ |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8278 src = src_end; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8279 coding.head_ascii = src - coding.source; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8280 } |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8281 detect_info.rejected |= ~CATEGORY_MASK_ISO_ESCAPE; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8282 break; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8283 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8284 } |
101040 | 8285 else if (! c && !inhibit_null_byte_detection) |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8286 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8287 null_byte_found = 1; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8288 if (eight_bit_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8289 break; |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8290 } |
95585
862c7386145c
(detect_coding): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95533
diff
changeset
|
8291 if (! eight_bit_found) |
862c7386145c
(detect_coding): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95533
diff
changeset
|
8292 coding.head_ascii++; |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8293 } |
95585
862c7386145c
(detect_coding): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95533
diff
changeset
|
8294 else if (! eight_bit_found) |
95533
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8295 coding.head_ascii++; |
831c8ee4d884
(detect_coding): Fix handling of coding->head_ascii.
Kenichi Handa <handa@m17n.org>
parents:
95397
diff
changeset
|
8296 } |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8297 |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8298 if (null_byte_found || eight_bit_found |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8299 || coding.head_ascii < coding.src_bytes |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8300 || detect_info.found) |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8301 { |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8302 if (coding.head_ascii == coding.src_bytes) |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8303 /* As all bytes are 7-bit, we can ignore non-ISO-2022 codings. */ |
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8304 for (i = 0; i < coding_category_raw_text; i++) |
88365 | 8305 { |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8306 category = coding_priorities[i]; |
90594
a965377e6761
(detect_coding_system): Fix for handling off
Kenichi Handa <handa@m17n.org>
parents:
90587
diff
changeset
|
8307 this = coding_categories + category; |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8308 if (detect_info.found & (1 << category)) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8309 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8310 } |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8311 else |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8312 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8313 if (null_byte_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8314 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8315 detect_info.checked |= ~CATEGORY_MASK_UTF_16; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8316 detect_info.rejected |= ~CATEGORY_MASK_UTF_16; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8317 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8318 for (i = 0; i < coding_category_raw_text; i++) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8319 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8320 category = coding_priorities[i]; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8321 this = coding_categories + category; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8322 |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8323 if (this->id < 0) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8324 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8325 /* No coding system of this category is defined. */ |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8326 detect_info.rejected |= (1 << category); |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8327 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8328 else if (category >= coding_category_raw_text) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8329 continue; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8330 else if (detect_info.checked & (1 << category)) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8331 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8332 if (highest |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8333 && (detect_info.found & (1 << category))) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8334 break; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8335 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8336 else if ((*(this->detector)) (&coding, &detect_info) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8337 && highest |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8338 && (detect_info.found & (1 << category))) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8339 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8340 if (category == coding_category_utf_16_auto) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8341 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8342 if (detect_info.found & CATEGORY_MASK_UTF_16_LE) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8343 category = coding_category_utf_16_le; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8344 else |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8345 category = coding_category_utf_16_be; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8346 } |
89974
2fef8edebd5c
(detect_coding_utf_16): Don't set detect_info->found if
Kenichi Handa <handa@m17n.org>
parents:
89933
diff
changeset
|
8347 break; |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8348 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8349 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8350 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8351 } |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8352 |
101197
ee5f395f3c19
(detect_coding_system): Fix handling of null_byte_fount.
Kenichi Handa <handa@m17n.org>
parents:
101174
diff
changeset
|
8353 if ((detect_info.rejected & CATEGORY_MASK_ANY) == CATEGORY_MASK_ANY |
ee5f395f3c19
(detect_coding_system): Fix handling of null_byte_fount.
Kenichi Handa <handa@m17n.org>
parents:
101174
diff
changeset
|
8354 || null_byte_found) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8355 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8356 detect_info.found = CATEGORY_MASK_RAW_TEXT; |
101197
ee5f395f3c19
(detect_coding_system): Fix handling of null_byte_fount.
Kenichi Handa <handa@m17n.org>
parents:
101174
diff
changeset
|
8357 id = CODING_SYSTEM_ID (Qno_conversion); |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8358 val = Fcons (make_number (id), Qnil); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8359 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8360 else if (! detect_info.rejected && ! detect_info.found) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8361 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8362 detect_info.found = CATEGORY_MASK_ANY; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8363 id = coding_categories[coding_category_undecided].id; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8364 val = Fcons (make_number (id), Qnil); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8365 } |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8366 else if (highest) |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8367 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8368 if (detect_info.found) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8369 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8370 detect_info.found = 1 << category; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8371 val = Fcons (make_number (this->id), Qnil); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8372 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8373 else |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8374 for (i = 0; i < coding_category_raw_text; i++) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8375 if (! (detect_info.rejected & (1 << coding_priorities[i]))) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8376 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8377 detect_info.found = 1 << coding_priorities[i]; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8378 id = coding_categories[coding_priorities[i]].id; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8379 val = Fcons (make_number (id), Qnil); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8380 break; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8381 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8382 } |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8383 else |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8384 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8385 int mask = detect_info.rejected | detect_info.found; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8386 int found = 0; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8387 |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8388 for (i = coding_category_raw_text - 1; i >= 0; i--) |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8389 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8390 category = coding_priorities[i]; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8391 if (! (mask & (1 << category))) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8392 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8393 found |= 1 << category; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8394 id = coding_categories[category].id; |
90594
a965377e6761
(detect_coding_system): Fix for handling off
Kenichi Handa <handa@m17n.org>
parents:
90587
diff
changeset
|
8395 if (id >= 0) |
a965377e6761
(detect_coding_system): Fix for handling off
Kenichi Handa <handa@m17n.org>
parents:
90587
diff
changeset
|
8396 val = Fcons (make_number (id), val); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8397 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8398 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8399 for (i = coding_category_raw_text - 1; i >= 0; i--) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8400 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8401 category = coding_priorities[i]; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8402 if (detect_info.found & (1 << category)) |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8403 { |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8404 id = coding_categories[category].id; |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8405 val = Fcons (make_number (id), val); |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8406 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8407 } |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8408 detect_info.found |= found; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8409 } |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8410 } |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8411 else if (base_category == coding_category_utf_8_auto) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8412 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8413 if (detect_coding_utf_8 (&coding, &detect_info)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8414 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8415 struct coding_system *this; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8416 |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8417 if (detect_info.found & CATEGORY_MASK_UTF_8_SIG) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8418 this = coding_categories + coding_category_utf_8_sig; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8419 else |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8420 this = coding_categories + coding_category_utf_8_nosig; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8421 val = Fcons (make_number (this->id), Qnil); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8422 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
8423 } |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8424 else if (base_category == coding_category_utf_16_auto) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8425 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8426 if (detect_coding_utf_16 (&coding, &detect_info)) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8427 { |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8428 struct coding_system *this; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8429 |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8430 if (detect_info.found & CATEGORY_MASK_UTF_16_LE) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8431 this = coding_categories + coding_category_utf_16_le; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8432 else if (detect_info.found & CATEGORY_MASK_UTF_16_BE) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8433 this = coding_categories + coding_category_utf_16_be; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8434 else if (detect_info.rejected & CATEGORY_MASK_UTF_16_LE_NOSIG) |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8435 this = coding_categories + coding_category_utf_16_be_nosig; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8436 else |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8437 this = coding_categories + coding_category_utf_16_le_nosig; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8438 val = Fcons (make_number (this->id), Qnil); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8439 } |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8440 } |
88365 | 8441 else |
8442 { | |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8443 detect_info.found = 1 << XINT (CODING_ATTR_CATEGORY (attrs)); |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8444 val = Fcons (make_number (coding.id), Qnil); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8445 } |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8446 |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8447 /* Then, detect eol-format if necessary. */ |
88365 | 8448 { |
100135
0e17542db552
(detect_coding_system): Initialize utf_16_le_eol to -1, val to
Kenichi Handa <handa@m17n.org>
parents:
100133
diff
changeset
|
8449 int normal_eol = -1, utf_16_be_eol = -1, utf_16_le_eol = -1; |
88365 | 8450 Lisp_Object tail; |
8451 | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8452 if (VECTORP (eol_type)) |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8453 { |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8454 if (detect_info.found & ~CATEGORY_MASK_UTF_16) |
93595
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8455 { |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8456 if (null_byte_found) |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8457 normal_eol = EOL_SEEN_LF; |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8458 else |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8459 normal_eol = detect_eol (coding.source, src_bytes, |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8460 coding_category_raw_text); |
ac4d127a841a
(CATEGORY_MASK_ANY): Add CATEGORY_MASK_UTF_16_AUTO.
Kenichi Handa <handa@m17n.org>
parents:
93323
diff
changeset
|
8461 } |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8462 if (detect_info.found & (CATEGORY_MASK_UTF_16_BE |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8463 | CATEGORY_MASK_UTF_16_BE_NOSIG)) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8464 utf_16_be_eol = detect_eol (coding.source, src_bytes, |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8465 coding_category_utf_16_be); |
89331
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8466 if (detect_info.found & (CATEGORY_MASK_UTF_16_LE |
1892a75ffcac
(CATEGORY_MASK_RAW_TEXT): New macro.
Kenichi Handa <handa@m17n.org>
parents:
89279
diff
changeset
|
8467 | CATEGORY_MASK_UTF_16_LE_NOSIG)) |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8468 utf_16_le_eol = detect_eol (coding.source, src_bytes, |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8469 coding_category_utf_16_le); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8470 } |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8471 else |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8472 { |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8473 if (EQ (eol_type, Qunix)) |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8474 normal_eol = utf_16_be_eol = utf_16_le_eol = EOL_SEEN_LF; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8475 else if (EQ (eol_type, Qdos)) |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8476 normal_eol = utf_16_be_eol = utf_16_le_eol = EOL_SEEN_CRLF; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8477 else |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8478 normal_eol = utf_16_be_eol = utf_16_le_eol = EOL_SEEN_CR; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8479 } |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8480 |
88365 | 8481 for (tail = val; CONSP (tail); tail = XCDR (tail)) |
8482 { | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8483 enum coding_category category; |
88365 | 8484 int this_eol; |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8485 |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8486 id = XINT (XCAR (tail)); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8487 attrs = CODING_ID_ATTRS (id); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8488 category = XINT (CODING_ATTR_CATEGORY (attrs)); |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8489 eol_type = CODING_ID_EOL_TYPE (id); |
88365 | 8490 if (VECTORP (eol_type)) |
8491 { | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8492 if (category == coding_category_utf_16_be |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8493 || category == coding_category_utf_16_be_nosig) |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8494 this_eol = utf_16_be_eol; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8495 else if (category == coding_category_utf_16_le |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8496 || category == coding_category_utf_16_le_nosig) |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8497 this_eol = utf_16_le_eol; |
88365 | 8498 else |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8499 this_eol = normal_eol; |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8500 |
88365 | 8501 if (this_eol == EOL_SEEN_LF) |
8502 XSETCAR (tail, AREF (eol_type, 0)); | |
8503 else if (this_eol == EOL_SEEN_CRLF) | |
8504 XSETCAR (tail, AREF (eol_type, 1)); | |
8505 else if (this_eol == EOL_SEEN_CR) | |
8506 XSETCAR (tail, AREF (eol_type, 2)); | |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8507 else |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8508 XSETCAR (tail, CODING_ID_NAME (id)); |
88365 | 8509 } |
89193
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8510 else |
311d061195ef
(detect_coding_utf_8): Check incomplete byte sequence.
Kenichi Handa <handa@m17n.org>
parents:
89184
diff
changeset
|
8511 XSETCAR (tail, CODING_ID_NAME (id)); |
88365 | 8512 } |
8513 } | |
8514 | |
100135
0e17542db552
(detect_coding_system): Initialize utf_16_le_eol to -1, val to
Kenichi Handa <handa@m17n.org>
parents:
100133
diff
changeset
|
8515 return (highest ? (CONSP (val) ? XCAR (val) : Qnil) : val); |
42104
d69c2368e549
(DECODE_COMPOSITION_END): Fixed a typo in the last
Sam Steingold <sds@gnu.org>
parents:
42103
diff
changeset
|
8516 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8517 |
88365 | 8518 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8519 DEFUN ("detect-coding-region", Fdetect_coding_region, Sdetect_coding_region, |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8520 2, 3, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8521 doc: /* Detect coding system of the text in the region between START and END. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8522 Return a list of possible coding systems ordered by priority. |
102737
f556415c326b
(Fdetect_coding_region, Fcoding_system_priority_list): Improve the
Kenichi Handa <handa@m17n.org>
parents:
102422
diff
changeset
|
8523 The coding systems to try and their priorities follows what |
f556415c326b
(Fdetect_coding_region, Fcoding_system_priority_list): Improve the
Kenichi Handa <handa@m17n.org>
parents:
102422
diff
changeset
|
8524 the function `coding-system-priority-list' (which see) returns. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8525 |
72552
6493d4697ad2
(Fdetect_coding_region, Fdetect_coding_string): Fix
Kenichi Handa <handa@m17n.org>
parents:
72395
diff
changeset
|
8526 If only ASCII characters are found (except for such ISO-2022 control |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8527 characters as ESC), it returns a list of single element `undecided' |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8528 or its subsidiary coding system according to a detected end-of-line |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8529 format. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8530 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8531 If optional argument HIGHEST is non-nil, return the coding system of |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8532 highest priority. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8533 (Lisp_Object start, Lisp_Object end, Lisp_Object highest) |
17052 | 8534 { |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8535 int from, to; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8536 int from_byte, to_byte; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8537 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8538 CHECK_NUMBER_COERCE_MARKER (start); |
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8539 CHECK_NUMBER_COERCE_MARKER (end); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8540 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8541 validate_region (&start, &end); |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8542 from = XINT (start), to = XINT (end); |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8543 from_byte = CHAR_TO_BYTE (from); |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8544 to_byte = CHAR_TO_BYTE (to); |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8545 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8546 if (from < GPT && to >= GPT) |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8547 move_gap_both (to, to_byte); |
88365 | 8548 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8549 return detect_coding_system (BYTE_POS_ADDR (from_byte), |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8550 to - from, to_byte - from_byte, |
34531
37f85e931855
(ONE_MORE_BYTE_CHECK_MULTIBYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34197
diff
changeset
|
8551 !NILP (highest), |
37f85e931855
(ONE_MORE_BYTE_CHECK_MULTIBYTE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
34197
diff
changeset
|
8552 !NILP (current_buffer |
88365 | 8553 ->enable_multibyte_characters), |
8554 Qnil); | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8555 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8556 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8557 DEFUN ("detect-coding-string", Fdetect_coding_string, Sdetect_coding_string, |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8558 1, 2, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8559 doc: /* Detect coding system of the text in STRING. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8560 Return a list of possible coding systems ordered by priority. |
102738
41e7ab490f69
(Fdetect_coding_string): Improve the docstrings.
Kenichi Handa <handa@m17n.org>
parents:
102737
diff
changeset
|
8561 The coding systems to try and their priorities follows what |
41e7ab490f69
(Fdetect_coding_string): Improve the docstrings.
Kenichi Handa <handa@m17n.org>
parents:
102737
diff
changeset
|
8562 the function `coding-system-priority-list' (which see) returns. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8563 |
72552
6493d4697ad2
(Fdetect_coding_region, Fdetect_coding_string): Fix
Kenichi Handa <handa@m17n.org>
parents:
72395
diff
changeset
|
8564 If only ASCII characters are found (except for such ISO-2022 control |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8565 characters as ESC), it returns a list of single element `undecided' |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8566 or its subsidiary coding system according to a detected end-of-line |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8567 format. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8568 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8569 If optional argument HIGHEST is non-nil, return the coding system of |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8570 highest priority. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8571 (Lisp_Object string, Lisp_Object highest) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8572 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8573 CHECK_STRING (string); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8574 |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46293
diff
changeset
|
8575 return detect_coding_system (SDATA (string), |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
8576 SCHARS (string), SBYTES (string), |
89483 | 8577 !NILP (highest), STRING_MULTIBYTE (string), |
88365 | 8578 Qnil); |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8579 } |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8580 |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8581 |
88365 | 8582 static INLINE int |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
8583 char_encodable_p (int c, Lisp_Object attrs) |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8584 { |
88365 | 8585 Lisp_Object tail; |
8586 struct charset *charset; | |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8587 Lisp_Object translation_table; |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8588 |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8589 translation_table = CODING_ATTR_TRANS_TBL (attrs); |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
8590 if (! NILP (translation_table)) |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8591 c = translate_char (translation_table, c); |
88365 | 8592 for (tail = CODING_ATTR_CHARSET_LIST (attrs); |
8593 CONSP (tail); tail = XCDR (tail)) | |
8594 { | |
8595 charset = CHARSET_FROM_ID (XINT (XCAR (tail))); | |
8596 if (CHAR_CHARSET_P (c, charset)) | |
8597 break; | |
8598 } | |
8599 return (! NILP (tail)); | |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8600 } |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8601 |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8602 |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8603 /* Return a list of coding systems that safely encode the text between |
88365 | 8604 START and END. If EXCLUDE is non-nil, it is a list of coding |
8605 systems not to check. The returned list doesn't contain any such | |
88889
4548f224c603
(Ffind_coding_systems_region_internal): Detect an
Kenichi Handa <handa@m17n.org>
parents:
88876
diff
changeset
|
8606 coding systems. In any case, if the text contains only ASCII or is |
88365 | 8607 unibyte, return t. */ |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8608 |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8609 DEFUN ("find-coding-systems-region-internal", |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8610 Ffind_coding_systems_region_internal, |
88365 | 8611 Sfind_coding_systems_region_internal, 2, 3, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
8612 doc: /* Internal use only. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8613 (Lisp_Object start, Lisp_Object end, Lisp_Object exclude) |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8614 { |
88365 | 8615 Lisp_Object coding_attrs_list, safe_codings; |
8616 EMACS_INT start_byte, end_byte; | |
88876
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
8617 const unsigned char *p, *pbeg, *pend; |
88365 | 8618 int c; |
103486
091a55d2d6f7
(Ffind_coding_systems_region_internal): Cache checked characters.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
103474
diff
changeset
|
8619 Lisp_Object tail, elt, work_table; |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8620 |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8621 if (STRINGP (start)) |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8622 { |
88365 | 8623 if (!STRING_MULTIBYTE (start) |
89483 | 8624 || SCHARS (start) == SBYTES (start)) |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8625 return Qt; |
88365 | 8626 start_byte = 0; |
89483 | 8627 end_byte = SBYTES (start); |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8628 } |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8629 else |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8630 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8631 CHECK_NUMBER_COERCE_MARKER (start); |
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8632 CHECK_NUMBER_COERCE_MARKER (end); |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8633 if (XINT (start) < BEG || XINT (end) > Z || XINT (start) > XINT (end)) |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8634 args_out_of_range (start, end); |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8635 if (NILP (current_buffer->enable_multibyte_characters)) |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8636 return Qt; |
88365 | 8637 start_byte = CHAR_TO_BYTE (XINT (start)); |
8638 end_byte = CHAR_TO_BYTE (XINT (end)); | |
8639 if (XINT (end) - XINT (start) == end_byte - start_byte) | |
8640 return Qt; | |
8641 | |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8642 if (XINT (start) < GPT && XINT (end) > GPT) |
88365 | 8643 { |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8644 if ((GPT - XINT (start)) < (XINT (end) - GPT)) |
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8645 move_gap_both (XINT (start), start_byte); |
88365 | 8646 else |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8647 move_gap_both (XINT (end), end_byte); |
88365 | 8648 } |
8649 } | |
8650 | |
8651 coding_attrs_list = Qnil; | |
8652 for (tail = Vcoding_system_list; CONSP (tail); tail = XCDR (tail)) | |
8653 if (NILP (exclude) | |
8654 || NILP (Fmemq (XCAR (tail), exclude))) | |
8655 { | |
8656 Lisp_Object attrs; | |
8657 | |
8658 attrs = AREF (CODING_SYSTEM_SPEC (XCAR (tail)), 0); | |
8659 if (EQ (XCAR (tail), CODING_ATTR_BASE_NAME (attrs)) | |
8660 && ! EQ (CODING_ATTR_TYPE (attrs), Qundecided)) | |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8661 { |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8662 ASET (attrs, coding_attr_trans_tbl, |
89861
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
8663 get_translation_table (attrs, 1, NULL)); |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8664 coding_attrs_list = Fcons (attrs, coding_attrs_list); |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8665 } |
88365 | 8666 } |
8667 | |
8668 if (STRINGP (start)) | |
89483 | 8669 p = pbeg = SDATA (start); |
88365 | 8670 else |
8671 p = pbeg = BYTE_POS_ADDR (start_byte); | |
8672 pend = p + (end_byte - start_byte); | |
8673 | |
8674 while (p < pend && ASCII_BYTE_P (*p)) p++; | |
8675 while (p < pend && ASCII_BYTE_P (*(pend - 1))) pend--; | |
8676 | |
103486
091a55d2d6f7
(Ffind_coding_systems_region_internal): Cache checked characters.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
103474
diff
changeset
|
8677 work_table = Fmake_char_table (Qnil, Qnil); |
88365 | 8678 while (p < pend) |
8679 { | |
8680 if (ASCII_BYTE_P (*p)) | |
8681 p++; | |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8682 else |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8683 { |
88365 | 8684 c = STRING_CHAR_ADVANCE (p); |
103486
091a55d2d6f7
(Ffind_coding_systems_region_internal): Cache checked characters.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
103474
diff
changeset
|
8685 if (!NILP (char_table_ref (work_table, c))) |
091a55d2d6f7
(Ffind_coding_systems_region_internal): Cache checked characters.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
103474
diff
changeset
|
8686 /* This character was already checked. Ignore it. */ |
091a55d2d6f7
(Ffind_coding_systems_region_internal): Cache checked characters.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
103474
diff
changeset
|
8687 continue; |
88365 | 8688 |
8689 charset_map_loaded = 0; | |
8690 for (tail = coding_attrs_list; CONSP (tail);) | |
8691 { | |
8692 elt = XCAR (tail); | |
8693 if (NILP (elt)) | |
8694 tail = XCDR (tail); | |
8695 else if (char_encodable_p (c, elt)) | |
8696 tail = XCDR (tail); | |
8697 else if (CONSP (XCDR (tail))) | |
8698 { | |
8699 XSETCAR (tail, XCAR (XCDR (tail))); | |
8700 XSETCDR (tail, XCDR (XCDR (tail))); | |
8701 } | |
8702 else | |
8703 { | |
8704 XSETCAR (tail, Qnil); | |
8705 tail = XCDR (tail); | |
8706 } | |
8707 } | |
8708 if (charset_map_loaded) | |
8709 { | |
8710 EMACS_INT p_offset = p - pbeg, pend_offset = pend - pbeg; | |
8711 | |
8712 if (STRINGP (start)) | |
89483 | 8713 pbeg = SDATA (start); |
88365 | 8714 else |
8715 pbeg = BYTE_POS_ADDR (start_byte); | |
8716 p = pbeg + p_offset; | |
8717 pend = pbeg + pend_offset; | |
8718 } | |
103486
091a55d2d6f7
(Ffind_coding_systems_region_internal): Cache checked characters.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
103474
diff
changeset
|
8719 char_table_set (work_table, c, Qt); |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8720 } |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8721 } |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8722 |
89905
37e044cc35f6
(Ffind_coding_systems_region_internal): Include raw-text and
Kenichi Handa <handa@m17n.org>
parents:
89892
diff
changeset
|
8723 safe_codings = list2 (Qraw_text, Qno_conversion); |
88365 | 8724 for (tail = coding_attrs_list; CONSP (tail); tail = XCDR (tail)) |
8725 if (! NILP (XCAR (tail))) | |
8726 safe_codings = Fcons (CODING_ATTR_BASE_NAME (XCAR (tail)), safe_codings); | |
49539
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
8727 |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
8728 return safe_codings; |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
8729 } |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
8730 |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
8731 |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8732 DEFUN ("unencodable-char-position", Funencodable_char_position, |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8733 Sunencodable_char_position, 3, 5, 0, |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8734 doc: /* |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8735 Return position of first un-encodable character in a region. |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8736 START and END specify the region and CODING-SYSTEM specifies the |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8737 encoding to check. Return nil if CODING-SYSTEM does encode the region. |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8738 |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8739 If optional 4th argument COUNT is non-nil, it specifies at most how |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8740 many un-encodable characters to search. In this case, the value is a |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8741 list of positions. |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8742 |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8743 If optional 5th argument STRING is non-nil, it is a string to search |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8744 for un-encodable characters. In that case, START and END are indexes |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8745 to the string. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8746 (Lisp_Object start, Lisp_Object end, Lisp_Object coding_system, Lisp_Object count, Lisp_Object string) |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8747 { |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8748 int n; |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8749 struct coding_system coding; |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8750 Lisp_Object attrs, charset_list, translation_table; |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8751 Lisp_Object positions; |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8752 int from, to; |
89483 | 8753 const unsigned char *p, *stop, *pend; |
8754 int ascii_compatible; | |
8755 | |
8756 setup_coding_system (Fcheck_coding_system (coding_system), &coding); | |
8757 attrs = CODING_ID_ATTRS (coding.id); | |
8758 if (EQ (CODING_ATTR_TYPE (attrs), Qraw_text)) | |
8759 return Qnil; | |
8760 ascii_compatible = ! NILP (CODING_ATTR_ASCII_COMPAT (attrs)); | |
8761 charset_list = CODING_ATTR_CHARSET_LIST (attrs); | |
89861
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
8762 translation_table = get_translation_table (attrs, 1, NULL); |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8763 |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8764 if (NILP (string)) |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8765 { |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8766 validate_region (&start, &end); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8767 from = XINT (start); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8768 to = XINT (end); |
89483 | 8769 if (NILP (current_buffer->enable_multibyte_characters) |
8770 || (ascii_compatible | |
8771 && (to - from) == (CHAR_TO_BYTE (to) - (CHAR_TO_BYTE (from))))) | |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8772 return Qnil; |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8773 p = CHAR_POS_ADDR (from); |
89483 | 8774 pend = CHAR_POS_ADDR (to); |
8775 if (from < GPT && to >= GPT) | |
8776 stop = GPT_ADDR; | |
48829
f6c59ca557c7
(Funencodable_char_position): Set pend correctly.
Kenichi Handa <handa@m17n.org>
parents:
48230
diff
changeset
|
8777 else |
89483 | 8778 stop = pend; |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8779 } |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8780 else |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8781 { |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8782 CHECK_STRING (string); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8783 CHECK_NATNUM (start); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8784 CHECK_NATNUM (end); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8785 from = XINT (start); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8786 to = XINT (end); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8787 if (from > to |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8788 || to > SCHARS (string)) |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8789 args_out_of_range_3 (string, start, end); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8790 if (! STRING_MULTIBYTE (string)) |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8791 return Qnil; |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8792 p = SDATA (string) + string_char_to_byte (string, from); |
89483 | 8793 stop = pend = SDATA (string) + string_char_to_byte (string, to); |
8794 if (ascii_compatible && (to - from) == (pend - p)) | |
8795 return Qnil; | |
8796 } | |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8797 |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8798 if (NILP (count)) |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8799 n = 1; |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8800 else |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8801 { |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8802 CHECK_NATNUM (count); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8803 n = XINT (count); |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8804 } |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8805 |
89483 | 8806 positions = Qnil; |
8807 while (1) | |
8808 { | |
8809 int c; | |
8810 | |
8811 if (ascii_compatible) | |
8812 while (p < stop && ASCII_BYTE_P (*p)) | |
8813 p++, from++; | |
8814 if (p >= stop) | |
8815 { | |
8816 if (p >= pend) | |
8817 break; | |
8818 stop = pend; | |
8819 p = GAP_END_ADDR; | |
8820 } | |
8821 | |
8822 c = STRING_CHAR_ADVANCE (p); | |
8823 if (! (ASCII_CHAR_P (c) && ascii_compatible) | |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8824 && ! char_charset (translate_char (translation_table, c), |
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8825 charset_list, NULL)) |
89483 | 8826 { |
8827 positions = Fcons (make_number (from), positions); | |
8828 n--; | |
8829 if (n == 0) | |
8830 break; | |
8831 } | |
8832 | |
8833 from++; | |
8834 } | |
8835 | |
8836 return (NILP (count) ? Fcar (positions) : Fnreverse (positions)); | |
8837 } | |
8838 | |
8839 | |
88365 | 8840 DEFUN ("check-coding-systems-region", Fcheck_coding_systems_region, |
8841 Scheck_coding_systems_region, 3, 3, 0, | |
8842 doc: /* Check if the region is encodable by coding systems. | |
8843 | |
8844 START and END are buffer positions specifying the region. | |
8845 CODING-SYSTEM-LIST is a list of coding systems to check. | |
8846 | |
8847 The value is an alist ((CODING-SYSTEM POS0 POS1 ...) ...), where | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
8848 CODING-SYSTEM is a member of CODING-SYSTEM-LIST and can't encode the |
88365 | 8849 whole region, POS0, POS1, ... are buffer positions where non-encodable |
8850 characters are found. | |
8851 | |
8852 If all coding systems in CODING-SYSTEM-LIST can encode the region, the | |
8853 value is nil. | |
8854 | |
8855 START may be a string. In that case, check if the string is | |
8856 encodable, and the value contains indices to the string instead of | |
102055
4d3a5c88cb2b
(Fcheck_coding_systems_region): Fix typo; Qt -> Qnil.
Kenichi Handa <handa@m17n.org>
parents:
101943
diff
changeset
|
8857 buffer positions. END is ignored. |
4d3a5c88cb2b
(Fcheck_coding_systems_region): Fix typo; Qt -> Qnil.
Kenichi Handa <handa@m17n.org>
parents:
101943
diff
changeset
|
8858 |
102058
4f60db600648
(Fcheck_coding_systems_region): Fix test for unibyte
Andreas Schwab <schwab@suse.de>
parents:
102055
diff
changeset
|
8859 If the current buffer (or START if it is a string) is unibyte, the value |
102055
4d3a5c88cb2b
(Fcheck_coding_systems_region): Fix typo; Qt -> Qnil.
Kenichi Handa <handa@m17n.org>
parents:
101943
diff
changeset
|
8860 is nil. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
8861 (Lisp_Object start, Lisp_Object end, Lisp_Object coding_system_list) |
88365 | 8862 { |
8863 Lisp_Object list; | |
8864 EMACS_INT start_byte, end_byte; | |
8865 int pos; | |
88876
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
8866 const unsigned char *p, *pbeg, *pend; |
88365 | 8867 int c; |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8868 Lisp_Object tail, elt, attrs; |
88365 | 8869 |
8870 if (STRINGP (start)) | |
8871 { | |
8872 if (!STRING_MULTIBYTE (start) | |
102058
4f60db600648
(Fcheck_coding_systems_region): Fix test for unibyte
Andreas Schwab <schwab@suse.de>
parents:
102055
diff
changeset
|
8873 || SCHARS (start) == SBYTES (start)) |
88365 | 8874 return Qnil; |
8875 start_byte = 0; | |
89483 | 8876 end_byte = SBYTES (start); |
88365 | 8877 pos = 0; |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
8878 } |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8879 else |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8880 { |
88365 | 8881 CHECK_NUMBER_COERCE_MARKER (start); |
8882 CHECK_NUMBER_COERCE_MARKER (end); | |
8883 if (XINT (start) < BEG || XINT (end) > Z || XINT (start) > XINT (end)) | |
8884 args_out_of_range (start, end); | |
8885 if (NILP (current_buffer->enable_multibyte_characters)) | |
8886 return Qnil; | |
8887 start_byte = CHAR_TO_BYTE (XINT (start)); | |
8888 end_byte = CHAR_TO_BYTE (XINT (end)); | |
8889 if (XINT (end) - XINT (start) == end_byte - start_byte) | |
102055
4d3a5c88cb2b
(Fcheck_coding_systems_region): Fix typo; Qt -> Qnil.
Kenichi Handa <handa@m17n.org>
parents:
101943
diff
changeset
|
8890 return Qnil; |
88365 | 8891 |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8892 if (XINT (start) < GPT && XINT (end) > GPT) |
88365 | 8893 { |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8894 if ((GPT - XINT (start)) < (XINT (end) - GPT)) |
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8895 move_gap_both (XINT (start), start_byte); |
88365 | 8896 else |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8897 move_gap_both (XINT (end), end_byte); |
88365 | 8898 } |
89394
6ffca50f25b9
(Fcheck_coding_systems_region): Fix type errors.
Dave Love <fx@gnu.org>
parents:
89373
diff
changeset
|
8899 pos = XINT (start); |
88365 | 8900 } |
8901 | |
8902 list = Qnil; | |
8903 for (tail = coding_system_list; CONSP (tail); tail = XCDR (tail)) | |
8904 { | |
8905 elt = XCAR (tail); | |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8906 attrs = AREF (CODING_SYSTEM_SPEC (elt), 0); |
89861
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
8907 ASET (attrs, coding_attr_trans_tbl, |
7160ded23e55
(get_translation_table): Allow max_lookup to be NULL.
Kenichi Handa <handa@m17n.org>
parents:
89859
diff
changeset
|
8908 get_translation_table (attrs, 1, NULL)); |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
8909 list = Fcons (Fcons (elt, Fcons (attrs, Qnil)), list); |
88365 | 8910 } |
8911 | |
8912 if (STRINGP (start)) | |
89483 | 8913 p = pbeg = SDATA (start); |
88365 | 8914 else |
8915 p = pbeg = BYTE_POS_ADDR (start_byte); | |
8916 pend = p + (end_byte - start_byte); | |
8917 | |
8918 while (p < pend && ASCII_BYTE_P (*p)) p++, pos++; | |
8919 while (p < pend && ASCII_BYTE_P (*(pend - 1))) pend--; | |
8920 | |
8921 while (p < pend) | |
8922 { | |
8923 if (ASCII_BYTE_P (*p)) | |
8924 p++; | |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8925 else |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8926 { |
88365 | 8927 c = STRING_CHAR_ADVANCE (p); |
8928 | |
8929 charset_map_loaded = 0; | |
8930 for (tail = list; CONSP (tail); tail = XCDR (tail)) | |
8931 { | |
8932 elt = XCDR (XCAR (tail)); | |
8933 if (! char_encodable_p (c, XCAR (elt))) | |
8934 XSETCDR (elt, Fcons (make_number (pos), XCDR (elt))); | |
8935 } | |
8936 if (charset_map_loaded) | |
8937 { | |
8938 EMACS_INT p_offset = p - pbeg, pend_offset = pend - pbeg; | |
8939 | |
8940 if (STRINGP (start)) | |
89483 | 8941 pbeg = SDATA (start); |
88365 | 8942 else |
8943 pbeg = BYTE_POS_ADDR (start_byte); | |
8944 p = pbeg + p_offset; | |
8945 pend = pbeg + pend_offset; | |
8946 } | |
8947 } | |
8948 pos++; | |
8949 } | |
8950 | |
8951 tail = list; | |
8952 list = Qnil; | |
8953 for (; CONSP (tail); tail = XCDR (tail)) | |
8954 { | |
8955 elt = XCAR (tail); | |
8956 if (CONSP (XCDR (XCDR (elt)))) | |
8957 list = Fcons (Fcons (XCAR (elt), Fnreverse (XCDR (XCDR (elt)))), | |
8958 list); | |
8959 } | |
8960 | |
8961 return list; | |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8962 } |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8963 |
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
8964 |
20803
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
8965 Lisp_Object |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8966 code_convert_region (Lisp_Object start, Lisp_Object end, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8967 Lisp_Object coding_system, Lisp_Object dst_object, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
8968 int encodep, int norecord) |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
8969 { |
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
8970 struct coding_system coding; |
88365 | 8971 EMACS_INT from, from_byte, to, to_byte; |
8972 Lisp_Object src_object; | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8973 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8974 CHECK_NUMBER_COERCE_MARKER (start); |
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
8975 CHECK_NUMBER_COERCE_MARKER (end); |
88365 | 8976 if (NILP (coding_system)) |
8977 coding_system = Qno_conversion; | |
8978 else | |
8979 CHECK_CODING_SYSTEM (coding_system); | |
8980 src_object = Fcurrent_buffer (); | |
8981 if (NILP (dst_object)) | |
8982 dst_object = src_object; | |
8983 else if (! EQ (dst_object, Qt)) | |
8984 CHECK_BUFFER (dst_object); | |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
8985 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8986 validate_region (&start, &end); |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8987 from = XFASTINT (start); |
88365 | 8988 from_byte = CHAR_TO_BYTE (from); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8989 to = XFASTINT (end); |
88365 | 8990 to_byte = CHAR_TO_BYTE (to); |
8991 | |
8992 setup_coding_system (coding_system, &coding); | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
8993 coding.mode |= CODING_MODE_LAST_BLOCK; |
88365 | 8994 |
8995 if (encodep) | |
8996 encode_coding_object (&coding, src_object, from, from_byte, to, to_byte, | |
8997 dst_object); | |
8998 else | |
8999 decode_coding_object (&coding, src_object, from, from_byte, to, to_byte, | |
9000 dst_object); | |
9001 if (! norecord) | |
9002 Vlast_coding_system_used = CODING_ID_NAME (coding.id); | |
9003 | |
9004 return (BUFFERP (dst_object) | |
9005 ? make_number (coding.produced_char) | |
9006 : coding.dst_object); | |
20803
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9007 } |
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9008 |
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9009 |
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9010 DEFUN ("decode-coding-region", Fdecode_coding_region, Sdecode_coding_region, |
88365 | 9011 3, 4, "r\nzCoding system: ", |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9012 doc: /* Decode the current region from the specified coding system. |
88365 | 9013 When called from a program, takes four arguments: |
9014 START, END, CODING-SYSTEM, and DESTINATION. | |
9015 START and END are buffer positions. | |
9016 | |
9017 Optional 4th arguments DESTINATION specifies where the decoded text goes. | |
91083
ff87badce376
(Fdecode_coding_region): Fix typo in docstring.
Kenichi Handa <handa@m17n.org>
parents:
91056
diff
changeset
|
9018 If nil, the region between START and END is replaced by the decoded text. |
98992
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9019 If buffer, the decoded text is inserted in that buffer after point (point |
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9020 does not move). |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
9021 In those cases, the length of the decoded text is returned. |
95353
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
9022 If DESTINATION is t, the decoded text is returned. |
88365 | 9023 |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9024 This function sets `last-coding-system-used' to the precise coding system |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9025 used (which may be different from CODING-SYSTEM if CODING-SYSTEM is |
95353
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
9026 not fully specified.) */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9027 (Lisp_Object start, Lisp_Object end, Lisp_Object coding_system, Lisp_Object destination) |
20803
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9028 { |
88365 | 9029 return code_convert_region (start, end, coding_system, destination, 0, 0); |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
9030 } |
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
9031 |
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
9032 DEFUN ("encode-coding-region", Fencode_coding_region, Sencode_coding_region, |
88365 | 9033 3, 4, "r\nzCoding system: ", |
9034 doc: /* Encode the current region by specified coding system. | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9035 When called from a program, takes four arguments: |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9036 START, END, CODING-SYSTEM and DESTINATION. |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9037 START and END are buffer positions. |
88365 | 9038 |
9039 Optional 4th arguments DESTINATION specifies where the encoded text goes. | |
9040 If nil, the region between START and END is replace by the encoded text. | |
98992
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9041 If buffer, the encoded text is inserted in that buffer after point (point |
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9042 does not move). |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
9043 In those cases, the length of the encoded text is returned. |
95353
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
9044 If DESTINATION is t, the encoded text is returned. |
88365 | 9045 |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9046 This function sets `last-coding-system-used' to the precise coding system |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9047 used (which may be different from CODING-SYSTEM if CODING-SYSTEM is |
95353
96d35f50fe34
(encode_coding_raw_text): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
95345
diff
changeset
|
9048 not fully specified.) */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9049 (Lisp_Object start, Lisp_Object end, Lisp_Object coding_system, Lisp_Object destination) |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
9050 { |
88365 | 9051 return code_convert_region (start, end, coding_system, destination, 1, 0); |
17052 | 9052 } |
9053 | |
20803
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9054 Lisp_Object |
109360
f37b85834f7e
Convert more function definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109179
diff
changeset
|
9055 code_convert_string (Lisp_Object string, Lisp_Object coding_system, |
f37b85834f7e
Convert more function definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109179
diff
changeset
|
9056 Lisp_Object dst_object, int encodep, int nocopy, int norecord) |
17052 | 9057 { |
9058 struct coding_system coding; | |
88365 | 9059 EMACS_INT chars, bytes; |
17052 | 9060 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
9061 CHECK_STRING (string); |
88365 | 9062 if (NILP (coding_system)) |
9063 { | |
9064 if (! norecord) | |
9065 Vlast_coding_system_used = Qno_conversion; | |
9066 if (NILP (dst_object)) | |
9067 return (nocopy ? Fcopy_sequence (string) : string); | |
9068 } | |
17052 | 9069 |
70520
b6740a317343
(setup_coding_system): For invalid coding-system, set
Kenichi Handa <handa@m17n.org>
parents:
69995
diff
changeset
|
9070 if (NILP (coding_system)) |
88365 | 9071 coding_system = Qno_conversion; |
9072 else | |
9073 CHECK_CODING_SYSTEM (coding_system); | |
9074 if (NILP (dst_object)) | |
9075 dst_object = Qt; | |
9076 else if (! EQ (dst_object, Qt)) | |
9077 CHECK_BUFFER (dst_object); | |
9078 | |
9079 setup_coding_system (coding_system, &coding); | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
9080 coding.mode |= CODING_MODE_LAST_BLOCK; |
89483 | 9081 chars = SCHARS (string); |
9082 bytes = SBYTES (string); | |
88365 | 9083 if (encodep) |
9084 encode_coding_object (&coding, string, 0, 0, chars, bytes, dst_object); | |
9085 else | |
9086 decode_coding_object (&coding, string, 0, 0, chars, bytes, dst_object); | |
9087 if (! norecord) | |
9088 Vlast_coding_system_used = CODING_ID_NAME (coding.id); | |
9089 | |
9090 return (BUFFERP (dst_object) | |
9091 ? make_number (coding.produced_char) | |
9092 : coding.dst_object); | |
20803
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9093 } |
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9094 |
0fa2183c587d
(ENCODE_ISO_CHARACTER): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
20794
diff
changeset
|
9095 |
22341
572ba933a4bf
(code_convert_string_norecord): New function.
Karl Heuer <kwzh@gnu.org>
parents:
22329
diff
changeset
|
9096 /* Encode or decode STRING according to CODING_SYSTEM. |
26847 | 9097 Do not set Vlast_coding_system_used. |
9098 | |
9099 This function is called only from macros DECODE_FILE and | |
9100 ENCODE_FILE, thus we ignore character composition. */ | |
22341
572ba933a4bf
(code_convert_string_norecord): New function.
Karl Heuer <kwzh@gnu.org>
parents:
22329
diff
changeset
|
9101 |
572ba933a4bf
(code_convert_string_norecord): New function.
Karl Heuer <kwzh@gnu.org>
parents:
22329
diff
changeset
|
9102 Lisp_Object |
109159
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
9103 code_convert_string_norecord (Lisp_Object string, Lisp_Object coding_system, |
3e9fdeb960d1
* coding.c, sysdep.c: Convert some more functions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109158
diff
changeset
|
9104 int encodep) |
22341
572ba933a4bf
(code_convert_string_norecord): New function.
Karl Heuer <kwzh@gnu.org>
parents:
22329
diff
changeset
|
9105 { |
88430
6418a272b97e
* coding.c: Delete unused variables.
Kenichi Handa <handa@m17n.org>
parents:
88365
diff
changeset
|
9106 return code_convert_string (string, coding_system, Qt, encodep, 0, 1); |
22341
572ba933a4bf
(code_convert_string_norecord): New function.
Karl Heuer <kwzh@gnu.org>
parents:
22329
diff
changeset
|
9107 } |
88365 | 9108 |
9109 | |
9110 DEFUN ("decode-coding-string", Fdecode_coding_string, Sdecode_coding_string, | |
9111 2, 4, 0, | |
9112 doc: /* Decode STRING which is encoded in CODING-SYSTEM, and return the result. | |
9113 | |
9114 Optional third arg NOCOPY non-nil means it is OK to return STRING itself | |
9115 if the decoding operation is trivial. | |
9116 | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9117 Optional fourth arg BUFFER non-nil means that the decoded text is |
98992
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9118 inserted in that buffer after point (point does not move). In this |
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9119 case, the return value is the length of the decoded text. |
88365 | 9120 |
9121 This function sets `last-coding-system-used' to the precise coding system | |
9122 used (which may be different from CODING-SYSTEM if CODING-SYSTEM is | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9123 not fully specified.) */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9124 (Lisp_Object string, Lisp_Object coding_system, Lisp_Object nocopy, Lisp_Object buffer) |
88365 | 9125 { |
9126 return code_convert_string (string, coding_system, buffer, | |
9127 0, ! NILP (nocopy), 0); | |
9128 } | |
9129 | |
9130 DEFUN ("encode-coding-string", Fencode_coding_string, Sencode_coding_string, | |
9131 2, 4, 0, | |
9132 doc: /* Encode STRING to CODING-SYSTEM, and return the result. | |
9133 | |
9134 Optional third arg NOCOPY non-nil means it is OK to return STRING | |
9135 itself if the encoding operation is trivial. | |
9136 | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9137 Optional fourth arg BUFFER non-nil means that the encoded text is |
98992
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9138 inserted in that buffer after point (point does not move). In this |
d4659edb9b7b
(Fencode_coding_region, Fdecode_coding_region)
Eli Zaretskii <eliz@gnu.org>
parents:
98951
diff
changeset
|
9139 case, the return value is the length of the encoded text. |
88365 | 9140 |
9141 This function sets `last-coding-system-used' to the precise coding system | |
9142 used (which may be different from CODING-SYSTEM if CODING-SYSTEM is | |
9143 not fully specified.) */) | |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9144 (Lisp_Object string, Lisp_Object coding_system, Lisp_Object nocopy, Lisp_Object buffer) |
88365 | 9145 { |
9146 return code_convert_string (string, coding_system, buffer, | |
88856 | 9147 1, ! NILP (nocopy), 1); |
88365 | 9148 } |
9149 | |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
9150 |
17052 | 9151 DEFUN ("decode-sjis-char", Fdecode_sjis_char, Sdecode_sjis_char, 1, 1, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9152 doc: /* Decode a Japanese character which has CODE in shift_jis encoding. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9153 Return the corresponding character. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9154 (Lisp_Object code) |
17052 | 9155 { |
88365 | 9156 Lisp_Object spec, attrs, val; |
9157 struct charset *charset_roman, *charset_kanji, *charset_kana, *charset; | |
9158 int c; | |
9159 | |
9160 CHECK_NATNUM (code); | |
9161 c = XFASTINT (code); | |
9162 CHECK_CODING_SYSTEM_GET_SPEC (Vsjis_coding_system, spec); | |
9163 attrs = AREF (spec, 0); | |
9164 | |
9165 if (ASCII_BYTE_P (c) | |
9166 && ! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) | |
9167 return code; | |
9168 | |
9169 val = CODING_ATTR_CHARSET_LIST (attrs); | |
9170 charset_roman = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
88497
d2b9e0d4c2f6
(Fdecode_sjis_char): Fix typo (0x7F->0xFF). Fix the
Kenichi Handa <handa@m17n.org>
parents:
88485
diff
changeset
|
9171 charset_kana = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); |
d2b9e0d4c2f6
(Fdecode_sjis_char): Fix typo (0x7F->0xFF). Fix the
Kenichi Handa <handa@m17n.org>
parents:
88485
diff
changeset
|
9172 charset_kanji = CHARSET_FROM_ID (XINT (XCAR (val))); |
88365 | 9173 |
9174 if (c <= 0x7F) | |
9175 charset = charset_roman; | |
9176 else if (c >= 0xA0 && c < 0xDF) | |
9177 { | |
9178 charset = charset_kana; | |
9179 c -= 0x80; | |
24065
7e291dea6141
(Fdecode_sjis_char): Decode Japanese Katakana character
Kenichi Handa <handa@m17n.org>
parents:
24056
diff
changeset
|
9180 } |
7e291dea6141
(Fdecode_sjis_char): Decode Japanese Katakana character
Kenichi Handa <handa@m17n.org>
parents:
24056
diff
changeset
|
9181 else |
7e291dea6141
(Fdecode_sjis_char): Decode Japanese Katakana character
Kenichi Handa <handa@m17n.org>
parents:
24056
diff
changeset
|
9182 { |
88497
d2b9e0d4c2f6
(Fdecode_sjis_char): Fix typo (0x7F->0xFF). Fix the
Kenichi Handa <handa@m17n.org>
parents:
88485
diff
changeset
|
9183 int s1 = c >> 8, s2 = c & 0xFF; |
88365 | 9184 |
9185 if (s1 < 0x81 || (s1 > 0x9F && s1 < 0xE0) || s1 > 0xEF | |
9186 || s2 < 0x40 || s2 == 0x7F || s2 > 0xFC) | |
9187 error ("Invalid code: %d", code); | |
9188 SJIS_TO_JIS (c); | |
9189 charset = charset_kanji; | |
9190 } | |
9191 c = DECODE_CHAR (charset, c); | |
9192 if (c < 0) | |
9193 error ("Invalid code: %d", code); | |
9194 return make_number (c); | |
17052 | 9195 } |
9196 | |
9197 | |
9198 DEFUN ("encode-sjis-char", Fencode_sjis_char, Sencode_sjis_char, 1, 1, 0, | |
73949
0d1207b43a5b
(Fencode_sjis_char, Fencode_big5_char): Improve argument/docstring consistency.
Juanma Barranquero <lekktu@gmail.com>
parents:
72552
diff
changeset
|
9199 doc: /* Encode a Japanese character CH to shift_jis encoding. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9200 Return the corresponding code in SJIS. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9201 (Lisp_Object ch) |
17052 | 9202 { |
88365 | 9203 Lisp_Object spec, attrs, charset_list; |
9204 int c; | |
9205 struct charset *charset; | |
9206 unsigned code; | |
9207 | |
9208 CHECK_CHARACTER (ch); | |
9209 c = XFASTINT (ch); | |
9210 CHECK_CODING_SYSTEM_GET_SPEC (Vsjis_coding_system, spec); | |
9211 attrs = AREF (spec, 0); | |
9212 | |
9213 if (ASCII_CHAR_P (c) | |
9214 && ! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) | |
9215 return ch; | |
9216 | |
9217 charset_list = CODING_ATTR_CHARSET_LIST (attrs); | |
9218 charset = char_charset (c, charset_list, &code); | |
9219 if (code == CHARSET_INVALID_CODE (charset)) | |
9220 error ("Can't encode by shift_jis encoding: %d", c); | |
9221 JIS_TO_SJIS (code); | |
9222 | |
9223 return make_number (code); | |
17052 | 9224 } |
9225 | |
9226 DEFUN ("decode-big5-char", Fdecode_big5_char, Sdecode_big5_char, 1, 1, 0, | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9227 doc: /* Decode a Big5 character which has CODE in BIG5 coding system. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9228 Return the corresponding character. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9229 (Lisp_Object code) |
17052 | 9230 { |
88365 | 9231 Lisp_Object spec, attrs, val; |
9232 struct charset *charset_roman, *charset_big5, *charset; | |
9233 int c; | |
9234 | |
9235 CHECK_NATNUM (code); | |
9236 c = XFASTINT (code); | |
9237 CHECK_CODING_SYSTEM_GET_SPEC (Vbig5_coding_system, spec); | |
9238 attrs = AREF (spec, 0); | |
9239 | |
9240 if (ASCII_BYTE_P (c) | |
9241 && ! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) | |
9242 return code; | |
9243 | |
9244 val = CODING_ATTR_CHARSET_LIST (attrs); | |
9245 charset_roman = CHARSET_FROM_ID (XINT (XCAR (val))), val = XCDR (val); | |
9246 charset_big5 = CHARSET_FROM_ID (XINT (XCAR (val))); | |
9247 | |
9248 if (c <= 0x7F) | |
9249 charset = charset_roman; | |
24324
2eec590faf26
(Fdecode_sjis_char, Fencode_sjis_char): Hanlde
Kenichi Handa <handa@m17n.org>
parents:
24316
diff
changeset
|
9250 else |
2eec590faf26
(Fdecode_sjis_char, Fencode_sjis_char): Hanlde
Kenichi Handa <handa@m17n.org>
parents:
24316
diff
changeset
|
9251 { |
88365 | 9252 int b1 = c >> 8, b2 = c & 0x7F; |
9253 if (b1 < 0xA1 || b1 > 0xFE | |
9254 || b2 < 0x40 || (b2 > 0x7E && b2 < 0xA1) || b2 > 0xFE) | |
9255 error ("Invalid code: %d", code); | |
9256 charset = charset_big5; | |
9257 } | |
9258 c = DECODE_CHAR (charset, (unsigned )c); | |
9259 if (c < 0) | |
9260 error ("Invalid code: %d", code); | |
9261 return make_number (c); | |
17052 | 9262 } |
9263 | |
9264 DEFUN ("encode-big5-char", Fencode_big5_char, Sencode_big5_char, 1, 1, 0, | |
73949
0d1207b43a5b
(Fencode_sjis_char, Fencode_big5_char): Improve argument/docstring consistency.
Juanma Barranquero <lekktu@gmail.com>
parents:
72552
diff
changeset
|
9265 doc: /* Encode the Big5 character CH to BIG5 coding system. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9266 Return the corresponding character code in Big5. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9267 (Lisp_Object ch) |
17052 | 9268 { |
88365 | 9269 Lisp_Object spec, attrs, charset_list; |
9270 struct charset *charset; | |
9271 int c; | |
9272 unsigned code; | |
9273 | |
9274 CHECK_CHARACTER (ch); | |
9275 c = XFASTINT (ch); | |
9276 CHECK_CODING_SYSTEM_GET_SPEC (Vbig5_coding_system, spec); | |
9277 attrs = AREF (spec, 0); | |
9278 if (ASCII_CHAR_P (c) | |
9279 && ! NILP (CODING_ATTR_ASCII_COMPAT (attrs))) | |
9280 return ch; | |
9281 | |
9282 charset_list = CODING_ATTR_CHARSET_LIST (attrs); | |
9283 charset = char_charset (c, charset_list, &code); | |
9284 if (code == CHARSET_INVALID_CODE (charset)) | |
9285 error ("Can't encode by Big5 encoding: %d", c); | |
9286 | |
9287 return make_number (code); | |
17052 | 9288 } |
88365 | 9289 |
20680
dd46027e8412
(code_convert_region): Always count chars inserted
Richard M. Stallman <rms@gnu.org>
parents:
20668
diff
changeset
|
9290 |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
9291 DEFUN ("set-terminal-coding-system-internal", Fset_terminal_coding_system_internal, |
83298
ed09a89e2b25
Fix UTF-8 tty input when first frame is an X frame. Steps towards multiple tty locale support.
Karoly Lorentey <lorentey@elte.hu>
parents:
83292
diff
changeset
|
9292 Sset_terminal_coding_system_internal, 1, 2, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9293 doc: /* Internal use only. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9294 (Lisp_Object coding_system, Lisp_Object terminal) |
17052 | 9295 { |
111237
6788b08ca420
Handle glyphless characters on tty.
Kenichi Handa <handa@m17n.org>
parents:
110997
diff
changeset
|
9296 struct terminal *term = get_terminal (terminal, 1); |
6788b08ca420
Handle glyphless characters on tty.
Kenichi Handa <handa@m17n.org>
parents:
110997
diff
changeset
|
9297 struct coding_system *terminal_coding = TERMINAL_TERMINAL_CODING (term); |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
9298 CHECK_SYMBOL (coding_system); |
83127
5182815e0ee1
Make terminal_coding and keyboard_coding display-local.
Karoly Lorentey <lorentey@elte.hu>
parents:
54320
diff
changeset
|
9299 setup_coding_system (Fcheck_coding_system (coding_system), terminal_coding); |
20150
402b6e5f4b58
(encode_designation_at_bol): Fix bug of finding graphic
Kenichi Handa <handa@m17n.org>
parents:
20105
diff
changeset
|
9300 /* We had better not send unsafe characters to terminal. */ |
91041 | 9301 terminal_coding->mode |= CODING_MODE_SAFE_ENCODING; |
110983 | 9302 /* Character composition should be disabled. */ |
91041 | 9303 terminal_coding->common_flags &= ~CODING_ANNOTATE_COMPOSITION_MASK; |
83127
5182815e0ee1
Make terminal_coding and keyboard_coding display-local.
Karoly Lorentey <lorentey@elte.hu>
parents:
54320
diff
changeset
|
9304 terminal_coding->src_multibyte = 1; |
5182815e0ee1
Make terminal_coding and keyboard_coding display-local.
Karoly Lorentey <lorentey@elte.hu>
parents:
54320
diff
changeset
|
9305 terminal_coding->dst_multibyte = 0; |
111237
6788b08ca420
Handle glyphless characters on tty.
Kenichi Handa <handa@m17n.org>
parents:
110997
diff
changeset
|
9306 if (terminal_coding->common_flags & CODING_REQUIRE_ENCODING_MASK) |
6788b08ca420
Handle glyphless characters on tty.
Kenichi Handa <handa@m17n.org>
parents:
110997
diff
changeset
|
9307 term->charset_list = coding_charset_list (terminal_coding); |
6788b08ca420
Handle glyphless characters on tty.
Kenichi Handa <handa@m17n.org>
parents:
110997
diff
changeset
|
9308 else |
111575
c1042b16fa46
coding.c (Fset_terminal_coding_system_internal): Fix previous change (set charset-ID list instead of charset-symbol list).
Kenichi Handa <handa@m17n.org>
parents:
111402
diff
changeset
|
9309 term->charset_list = Fcons (make_number (charset_ascii), Qnil); |
17052 | 9310 return Qnil; |
9311 } | |
9312 | |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9313 DEFUN ("set-safe-terminal-coding-system-internal", |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9314 Fset_safe_terminal_coding_system_internal, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9315 Sset_safe_terminal_coding_system_internal, 1, 1, 0, |
41006 | 9316 doc: /* Internal use only. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9317 (Lisp_Object coding_system) |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9318 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
9319 CHECK_SYMBOL (coding_system); |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9320 setup_coding_system (Fcheck_coding_system (coding_system), |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9321 &safe_terminal_coding); |
110983 | 9322 /* Character composition should be disabled. */ |
88365 | 9323 safe_terminal_coding.common_flags &= ~CODING_ANNOTATE_COMPOSITION_MASK; |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
9324 safe_terminal_coding.src_multibyte = 1; |
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
9325 safe_terminal_coding.dst_multibyte = 0; |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9326 return Qnil; |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9327 } |
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
9328 |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
9329 DEFUN ("terminal-coding-system", Fterminal_coding_system, |
83298
ed09a89e2b25
Fix UTF-8 tty input when first frame is an X frame. Steps towards multiple tty locale support.
Karoly Lorentey <lorentey@elte.hu>
parents:
83292
diff
changeset
|
9330 Sterminal_coding_system, 0, 1, 0, |
83431
76396de7f50a
Rename `struct device' to `struct terminal'. Rename some terminal-related functions similarly.
Karoly Lorentey <lorentey@elte.hu>
parents:
83423
diff
changeset
|
9331 doc: /* Return coding system specified for terminal output on the given terminal. |
103052
e68707cf48a5
* keyboard.c (Fset_input_meta_mode): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents:
103035
diff
changeset
|
9332 TERMINAL may be a terminal object, a frame, or nil for the selected |
83431
76396de7f50a
Rename `struct device' to `struct terminal'. Rename some terminal-related functions similarly.
Karoly Lorentey <lorentey@elte.hu>
parents:
83423
diff
changeset
|
9333 frame's terminal device. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9334 (Lisp_Object terminal) |
17052 | 9335 { |
91046 | 9336 struct coding_system *terminal_coding |
9337 = TERMINAL_TERMINAL_CODING (get_terminal (terminal, 1)); | |
9338 Lisp_Object coding_system = CODING_ID_NAME (terminal_coding->id); | |
9339 | |
90011
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
9340 /* For backward compatibility, return nil if it is `undecided'. */ |
90359
041f75914d0c
(produce_composition): Compare charbuf[i] instead of
Kenichi Handa <handa@m17n.org>
parents:
90354
diff
changeset
|
9341 return (! EQ (coding_system, Qundecided) ? coding_system : Qnil); |
17052 | 9342 } |
9343 | |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
9344 DEFUN ("set-keyboard-coding-system-internal", Fset_keyboard_coding_system_internal, |
83298
ed09a89e2b25
Fix UTF-8 tty input when first frame is an X frame. Steps towards multiple tty locale support.
Karoly Lorentey <lorentey@elte.hu>
parents:
83292
diff
changeset
|
9345 Sset_keyboard_coding_system_internal, 1, 2, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9346 doc: /* Internal use only. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9347 (Lisp_Object coding_system, Lisp_Object terminal) |
17052 | 9348 { |
83431
76396de7f50a
Rename `struct device' to `struct terminal'. Rename some terminal-related functions similarly.
Karoly Lorentey <lorentey@elte.hu>
parents:
83423
diff
changeset
|
9349 struct terminal *t = get_terminal (terminal, 1); |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40461
diff
changeset
|
9350 CHECK_SYMBOL (coding_system); |
103655
e2d67c929da2
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
103486
diff
changeset
|
9351 if (NILP (coding_system)) |
e2d67c929da2
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
103486
diff
changeset
|
9352 coding_system = Qno_conversion; |
e2d67c929da2
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
103486
diff
changeset
|
9353 else |
e2d67c929da2
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
103486
diff
changeset
|
9354 Fcheck_coding_system (coding_system); |
e2d67c929da2
(setup_coding_system): Initialize
Kenichi Handa <handa@m17n.org>
parents:
103486
diff
changeset
|
9355 setup_coding_system (coding_system, TERMINAL_KEYBOARD_CODING (t)); |
110983 | 9356 /* Character composition should be disabled. */ |
91041 | 9357 TERMINAL_KEYBOARD_CODING (t)->common_flags |
9358 &= ~CODING_ANNOTATE_COMPOSITION_MASK; | |
17052 | 9359 return Qnil; |
9360 } | |
9361 | |
9362 DEFUN ("keyboard-coding-system", | |
91046 | 9363 Fkeyboard_coding_system, Skeyboard_coding_system, 0, 1, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9364 doc: /* Return coding system specified for decoding keyboard input. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9365 (Lisp_Object terminal) |
17052 | 9366 { |
91046 | 9367 return CODING_ID_NAME (TERMINAL_KEYBOARD_CODING |
9368 (get_terminal (terminal, 1))->id); | |
17052 | 9369 } |
9370 | |
9371 | |
18536
69c0e220b626
(Vstandard_character_unification_table_for_decode):
Kenichi Handa <handa@m17n.org>
parents:
18523
diff
changeset
|
9372 DEFUN ("find-operation-coding-system", Ffind_operation_coding_system, |
69c0e220b626
(Vstandard_character_unification_table_for_decode):
Kenichi Handa <handa@m17n.org>
parents:
18523
diff
changeset
|
9373 Sfind_operation_coding_system, 1, MANY, 0, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9374 doc: /* Choose a coding system for an operation based on the target name. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9375 The value names a pair of coding systems: (DECODING-SYSTEM . ENCODING-SYSTEM). |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9376 DECODING-SYSTEM is the coding system to use for decoding |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9377 \(in case OPERATION does decoding), and ENCODING-SYSTEM is the coding system |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9378 for encoding (in case OPERATION does encoding). |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9379 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9380 The first argument OPERATION specifies an I/O primitive: |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9381 For file I/O, `insert-file-contents' or `write-region'. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9382 For process I/O, `call-process', `call-process-region', or `start-process'. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9383 For network I/O, `open-network-stream'. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9384 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9385 The remaining arguments should be the same arguments that were passed |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9386 to the primitive. Depending on which primitive, one of those arguments |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9387 is selected as the TARGET. For example, if OPERATION does file I/O, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9388 whichever argument specifies the file name is TARGET. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9389 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9390 TARGET has a meaning which depends on OPERATION: |
70948
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9391 For file I/O, TARGET is a file name (except for the special case below). |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9392 For process I/O, TARGET is a process name. |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9393 For network I/O, TARGET is a service name or a port number. |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9394 |
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9395 This function looks up what is specified for TARGET in |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9396 `file-coding-system-alist', `process-coding-system-alist', |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9397 or `network-coding-system-alist' depending on OPERATION. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9398 They may specify a coding system, a cons of coding systems, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9399 or a function symbol to call. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9400 In the last case, we call the function with one argument, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9401 which is a list of all the arguments given to this function. |
81611
ae42ad5f89e6
(Ffind_operation_coding_system): Docstring improved.
Kenichi Handa <handa@m17n.org>
parents:
75348
diff
changeset
|
9402 If the function can't decide a coding system, it can return |
ae42ad5f89e6
(Ffind_operation_coding_system): Docstring improved.
Kenichi Handa <handa@m17n.org>
parents:
75348
diff
changeset
|
9403 `undecided' so that the normal code-detection is performed. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
9404 |
70948
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9405 If OPERATION is `insert-file-contents', the argument corresponding to |
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9406 TARGET may be a cons (FILENAME . BUFFER). In that case, FILENAME is a |
71084
ccef92f2f7f8
(Ffind_operation_coding_system): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
71070
diff
changeset
|
9407 file name to look up, and BUFFER is a buffer that contains the file's |
ccef92f2f7f8
(Ffind_operation_coding_system): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
71070
diff
changeset
|
9408 contents (not yet decoded). If `file-coding-system-alist' specifies a |
71070
0c8ac7192244
(Ffind_operation_coding_system): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
71039
diff
changeset
|
9409 function to call for FILENAME, that function should examine the |
0c8ac7192244
(Ffind_operation_coding_system): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
71039
diff
changeset
|
9410 contents of BUFFER instead of reading the file. |
70948
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9411 |
78152
5e5f359984e5
(Ffind_operation_coding_system): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents:
75348
diff
changeset
|
9412 usage: (find-operation-coding-system OPERATION ARGUMENTS...) */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9413 (int nargs, Lisp_Object *args) |
17052 | 9414 { |
9415 Lisp_Object operation, target_idx, target, val; | |
9416 register Lisp_Object chain; | |
9417 | |
9418 if (nargs < 2) | |
9419 error ("Too few arguments"); | |
9420 operation = args[0]; | |
9421 if (!SYMBOLP (operation) | |
9422 || !INTEGERP (target_idx = Fget (operation, Qtarget_idx))) | |
93877
62d97ebb13a9
* coding.c (detect_coding_emacs_mule)
Michael Albinus <michael.albinus@gmx.de>
parents:
93595
diff
changeset
|
9423 error ("Invalid first argument"); |
17052 | 9424 if (nargs < 1 + XINT (target_idx)) |
9425 error ("Too few arguments for operation: %s", | |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46293
diff
changeset
|
9426 SDATA (SYMBOL_NAME (operation))); |
17052 | 9427 target = args[XINT (target_idx) + 1]; |
9428 if (!(STRINGP (target) | |
70948
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9429 || (EQ (operation, Qinsert_file_contents) && CONSP (target) |
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9430 && STRINGP (XCAR (target)) && BUFFERP (XCDR (target))) |
17052 | 9431 || (EQ (operation, Qopen_network_stream) && INTEGERP (target)))) |
88365 | 9432 error ("Invalid %dth argument", XINT (target_idx) + 1); |
70948
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9433 if (CONSP (target)) |
7ea8b1c11d80
(Ffind_operation_coding_system): Allow (FILENAME . BUFFER) in TARGET.
Kenichi Handa <handa@m17n.org>
parents:
70704
diff
changeset
|
9434 target = XCAR (target); |
17052 | 9435 |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18536
diff
changeset
|
9436 chain = ((EQ (operation, Qinsert_file_contents) |
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18536
diff
changeset
|
9437 || EQ (operation, Qwrite_region)) |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9438 ? Vfile_coding_system_alist |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18536
diff
changeset
|
9439 : (EQ (operation, Qopen_network_stream) |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9440 ? Vnetwork_coding_system_alist |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9441 : Vprocess_coding_system_alist)); |
17052 | 9442 if (NILP (chain)) |
9443 return Qnil; | |
9444 | |
25662
0a7261c1d487
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25370
diff
changeset
|
9445 for (; CONSP (chain); chain = XCDR (chain)) |
17052 | 9446 { |
19747
bed06df9cbc5
(setup_coding_system, Ffind_operation_coding_system)
Richard M. Stallman <rms@gnu.org>
parents:
19743
diff
changeset
|
9447 Lisp_Object elt; |
88365 | 9448 |
25662
0a7261c1d487
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25370
diff
changeset
|
9449 elt = XCAR (chain); |
17052 | 9450 if (CONSP (elt) |
9451 && ((STRINGP (target) | |
25662
0a7261c1d487
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25370
diff
changeset
|
9452 && STRINGP (XCAR (elt)) |
0a7261c1d487
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25370
diff
changeset
|
9453 && fast_string_match (XCAR (elt), target) >= 0) |
0a7261c1d487
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25370
diff
changeset
|
9454 || (INTEGERP (target) && EQ (target, XCAR (elt))))) |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9455 { |
25662
0a7261c1d487
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25370
diff
changeset
|
9456 val = XCDR (elt); |
19763
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9457 /* Here, if VAL is both a valid coding system and a valid |
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9458 function symbol, we return VAL as a coding system. */ |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9459 if (CONSP (val)) |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9460 return val; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9461 if (! SYMBOLP (val)) |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9462 return Qnil; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9463 if (! NILP (Fcoding_system_p (val))) |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9464 return Fcons (val, val); |
19763
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9465 if (! NILP (Ffboundp (val))) |
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9466 { |
72188 | 9467 /* We use call1 rather than safe_call1 |
9468 so as to get bug reports about functions called here | |
9469 which don't handle the current interface. */ | |
72180
f3bc55b96df5
(Ffind_operation_coding_system): Revert the change from 2006-05-29.
Eli Zaretskii <eliz@gnu.org>
parents:
71972
diff
changeset
|
9470 val = call1 (val, Flist (nargs, args)); |
19763
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9471 if (CONSP (val)) |
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9472 return val; |
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9473 if (SYMBOLP (val) && ! NILP (Fcoding_system_p (val))) |
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9474 return Fcons (val, val); |
ab2fd2c85986
(Ffind_operation_coding_system): If a function in
Kenichi Handa <handa@m17n.org>
parents:
19758
diff
changeset
|
9475 } |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9476 return Qnil; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
9477 } |
17052 | 9478 } |
9479 return Qnil; | |
9480 } | |
9481 | |
88365 | 9482 DEFUN ("set-coding-system-priority", Fset_coding_system_priority, |
88845
64b8f6168269
(Fset_coding_system_priority): Allow null arg list.
Dave Love <fx@gnu.org>
parents:
88771
diff
changeset
|
9483 Sset_coding_system_priority, 0, MANY, 0, |
88645 | 9484 doc: /* Assign higher priority to the coding systems given as arguments. |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9485 If multiple coding systems belong to the same category, |
89519
040a08a2a879
(Fread_coding_system): Fix arg of XSETSTRING.
Dave Love <fx@gnu.org>
parents:
89483
diff
changeset
|
9486 all but the first one are ignored. |
040a08a2a879
(Fread_coding_system): Fix arg of XSETSTRING.
Dave Love <fx@gnu.org>
parents:
89483
diff
changeset
|
9487 |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
9488 usage: (set-coding-system-priority &rest coding-systems) */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9489 (int nargs, Lisp_Object *args) |
88365 | 9490 { |
9491 int i, j; | |
9492 int changed[coding_category_max]; | |
9493 enum coding_category priorities[coding_category_max]; | |
9494 | |
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109159
diff
changeset
|
9495 memset (changed, 0, sizeof changed); |
88365 | 9496 |
9497 for (i = j = 0; i < nargs; i++) | |
9498 { | |
9499 enum coding_category category; | |
9500 Lisp_Object spec, attrs; | |
9501 | |
9502 CHECK_CODING_SYSTEM_GET_SPEC (args[i], spec); | |
9503 attrs = AREF (spec, 0); | |
9504 category = XINT (CODING_ATTR_CATEGORY (attrs)); | |
9505 if (changed[category]) | |
9506 /* Ignore this coding system because a coding system of the | |
9507 same category already had a higher priority. */ | |
9508 continue; | |
9509 changed[category] = 1; | |
9510 priorities[j++] = category; | |
9511 if (coding_categories[category].id >= 0 | |
9512 && ! EQ (args[i], CODING_ID_NAME (coding_categories[category].id))) | |
9513 setup_coding_system (args[i], &coding_categories[category]); | |
89467
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9514 Fset (AREF (Vcoding_category_table, category), args[i]); |
88365 | 9515 } |
9516 | |
9517 /* Now we have decided top J priorities. Reflect the order of the | |
9518 original priorities to the remaining priorities. */ | |
9519 | |
9520 for (i = j, j = 0; i < coding_category_max; i++, j++) | |
9521 { | |
9522 while (j < coding_category_max | |
9523 && changed[coding_priorities[j]]) | |
9524 j++; | |
9525 if (j == coding_category_max) | |
9526 abort (); | |
9527 priorities[i] = coding_priorities[j]; | |
9528 } | |
9529 | |
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109159
diff
changeset
|
9530 memcpy (coding_priorities, priorities, sizeof priorities); |
89467
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9531 |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9532 /* Update `coding-category-list'. */ |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9533 Vcoding_category_list = Qnil; |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9534 for (i = coding_category_max - 1; i >= 0; i--) |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9535 Vcoding_category_list |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9536 = Fcons (AREF (Vcoding_category_table, priorities[i]), |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
9537 Vcoding_category_list); |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
9538 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
9539 return Qnil; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
9540 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
9541 |
88365 | 9542 DEFUN ("coding-system-priority-list", Fcoding_system_priority_list, |
9543 Scoding_system_priority_list, 0, 1, 0, | |
88645 | 9544 doc: /* Return a list of coding systems ordered by their priorities. |
102737
f556415c326b
(Fdetect_coding_region, Fcoding_system_priority_list): Improve the
Kenichi Handa <handa@m17n.org>
parents:
102422
diff
changeset
|
9545 The list contains a subset of coding systems; i.e. coding systems |
f556415c326b
(Fdetect_coding_region, Fcoding_system_priority_list): Improve the
Kenichi Handa <handa@m17n.org>
parents:
102422
diff
changeset
|
9546 assigned to each coding category (see `coding-category-list'). |
f556415c326b
(Fdetect_coding_region, Fcoding_system_priority_list): Improve the
Kenichi Handa <handa@m17n.org>
parents:
102422
diff
changeset
|
9547 |
88645 | 9548 HIGHESTP non-nil means just return the highest priority one. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9549 (Lisp_Object highestp) |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
9550 { |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
9551 int i; |
22954
928b337d953b
Avoid using initializers for Lisp_Object.
Richard M. Stallman <rms@gnu.org>
parents:
22874
diff
changeset
|
9552 Lisp_Object val; |
928b337d953b
Avoid using initializers for Lisp_Object.
Richard M. Stallman <rms@gnu.org>
parents:
22874
diff
changeset
|
9553 |
88365 | 9554 for (i = 0, val = Qnil; i < coding_category_max; i++) |
9555 { | |
9556 enum coding_category category = coding_priorities[i]; | |
9557 int id = coding_categories[category].id; | |
9558 Lisp_Object attrs; | |
9559 | |
9560 if (id < 0) | |
9561 continue; | |
9562 attrs = CODING_ID_ATTRS (id); | |
9563 if (! NILP (highestp)) | |
9564 return CODING_ATTR_BASE_NAME (attrs); | |
9565 val = Fcons (CODING_ATTR_BASE_NAME (attrs), val); | |
9566 } | |
9567 return Fnreverse (val); | |
9568 } | |
9569 | |
105959
ba3ffbd9c422
* process.c (ifflag_def): Make flag_sym constant.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105877
diff
changeset
|
9570 static const char *const suffixes[] = { "-unix", "-dos", "-mac" }; |
88631
780b91d4a7e5
(setup_iso_safe_charsets): Fix arg decl for K&R.
Dave Love <fx@gnu.org>
parents:
88607
diff
changeset
|
9571 |
88365 | 9572 static Lisp_Object |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
9573 make_subsidiaries (Lisp_Object base) |
88365 | 9574 { |
9575 Lisp_Object subsidiaries; | |
89483 | 9576 int base_name_len = SBYTES (SYMBOL_NAME (base)); |
88365 | 9577 char *buf = (char *) alloca (base_name_len + 6); |
9578 int i; | |
89483 | 9579 |
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109159
diff
changeset
|
9580 memcpy (buf, SDATA (SYMBOL_NAME (base)), base_name_len); |
88365 | 9581 subsidiaries = Fmake_vector (make_number (3), Qnil); |
9582 for (i = 0; i < 3; i++) | |
9583 { | |
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109159
diff
changeset
|
9584 memcpy (buf + base_name_len, suffixes[i], strlen (suffixes[i]) + 1); |
88365 | 9585 ASET (subsidiaries, i, intern (buf)); |
9586 } | |
9587 return subsidiaries; | |
9588 } | |
9589 | |
22226
557fac086b1b
(ascii_skip_code): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22186
diff
changeset
|
9590 |
49539
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
9591 DEFUN ("define-coding-system-internal", Fdefine_coding_system_internal, |
88365 | 9592 Sdefine_coding_system_internal, coding_arg_max, MANY, 0, |
88544
f464d728344c
(Vchar_coding_system_table, Qchar_coding_system):
Dave Love <fx@gnu.org>
parents:
88510
diff
changeset
|
9593 doc: /* For internal use only. |
f464d728344c
(Vchar_coding_system_table, Qchar_coding_system):
Dave Love <fx@gnu.org>
parents:
88510
diff
changeset
|
9594 usage: (define-coding-system-internal ...) */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
9595 (int nargs, Lisp_Object *args) |
88365 | 9596 { |
9597 Lisp_Object name; | |
9598 Lisp_Object spec_vec; /* [ ATTRS ALIASE EOL_TYPE ] */ | |
9599 Lisp_Object attrs; /* Vector of attributes. */ | |
9600 Lisp_Object eol_type; | |
9601 Lisp_Object aliases; | |
9602 Lisp_Object coding_type, charset_list, safe_charsets; | |
9603 enum coding_category category; | |
9604 Lisp_Object tail, val; | |
9605 int max_charset_id = 0; | |
9606 int i; | |
9607 | |
9608 if (nargs < coding_arg_max) | |
9609 goto short_args; | |
9610 | |
9611 attrs = Fmake_vector (make_number (coding_attr_last_index), Qnil); | |
9612 | |
9613 name = args[coding_arg_name]; | |
9614 CHECK_SYMBOL (name); | |
9615 CODING_ATTR_BASE_NAME (attrs) = name; | |
9616 | |
9617 val = args[coding_arg_mnemonic]; | |
9618 if (! STRINGP (val)) | |
9619 CHECK_CHARACTER (val); | |
9620 CODING_ATTR_MNEMONIC (attrs) = val; | |
9621 | |
9622 coding_type = args[coding_arg_coding_type]; | |
9623 CHECK_SYMBOL (coding_type); | |
9624 CODING_ATTR_TYPE (attrs) = coding_type; | |
9625 | |
9626 charset_list = args[coding_arg_charset_list]; | |
9627 if (SYMBOLP (charset_list)) | |
9628 { | |
9629 if (EQ (charset_list, Qiso_2022)) | |
9630 { | |
9631 if (! EQ (coding_type, Qiso_2022)) | |
9632 error ("Invalid charset-list"); | |
9633 charset_list = Viso_2022_charset_list; | |
9634 } | |
9635 else if (EQ (charset_list, Qemacs_mule)) | |
9636 { | |
9637 if (! EQ (coding_type, Qemacs_mule)) | |
9638 error ("Invalid charset-list"); | |
9639 charset_list = Vemacs_mule_charset_list; | |
9640 } | |
9641 for (tail = charset_list; CONSP (tail); tail = XCDR (tail)) | |
9642 if (max_charset_id < XFASTINT (XCAR (tail))) | |
9643 max_charset_id = XFASTINT (XCAR (tail)); | |
9644 } | |
9645 else | |
9646 { | |
9647 charset_list = Fcopy_sequence (charset_list); | |
91046 | 9648 for (tail = charset_list; CONSP (tail); tail = XCDR (tail)) |
88365 | 9649 { |
9650 struct charset *charset; | |
9651 | |
91046 | 9652 val = XCAR (tail); |
88365 | 9653 CHECK_CHARSET_GET_CHARSET (val, charset); |
9654 if (EQ (coding_type, Qiso_2022) | |
9655 ? CHARSET_ISO_FINAL (charset) < 0 | |
9656 : EQ (coding_type, Qemacs_mule) | |
9657 ? CHARSET_EMACS_MULE_ID (charset) < 0 | |
9658 : 0) | |
9659 error ("Can't handle charset `%s'", | |
89483 | 9660 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
9661 | |
9662 XSETCAR (tail, make_number (charset->id)); | |
88365 | 9663 if (max_charset_id < charset->id) |
9664 max_charset_id = charset->id; | |
9665 } | |
9666 } | |
9667 CODING_ATTR_CHARSET_LIST (attrs) = charset_list; | |
9668 | |
102186
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
9669 safe_charsets = make_uninit_string (max_charset_id + 1); |
a12d39ca6870
* coding.h (struct coding_system): Make safe_charsets a pointer to
Andreas Schwab <schwab@suse.de>
parents:
102115
diff
changeset
|
9670 memset (SDATA (safe_charsets), 255, max_charset_id + 1); |
88365 | 9671 for (tail = charset_list; CONSP (tail); tail = XCDR (tail)) |
89483 | 9672 SSET (safe_charsets, XFASTINT (XCAR (tail)), 0); |
88365 | 9673 CODING_ATTR_SAFE_CHARSETS (attrs) = safe_charsets; |
9674 | |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9675 CODING_ATTR_ASCII_COMPAT (attrs) = args[coding_arg_ascii_compatible_p]; |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9676 |
88365 | 9677 val = args[coding_arg_decode_translation_table]; |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
9678 if (! CHAR_TABLE_P (val) && ! CONSP (val)) |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
9679 CHECK_SYMBOL (val); |
88365 | 9680 CODING_ATTR_DECODE_TBL (attrs) = val; |
9681 | |
9682 val = args[coding_arg_encode_translation_table]; | |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
9683 if (! CHAR_TABLE_P (val) && ! CONSP (val)) |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
9684 CHECK_SYMBOL (val); |
88365 | 9685 CODING_ATTR_ENCODE_TBL (attrs) = val; |
9686 | |
9687 val = args[coding_arg_post_read_conversion]; | |
9688 CHECK_SYMBOL (val); | |
9689 CODING_ATTR_POST_READ (attrs) = val; | |
9690 | |
9691 val = args[coding_arg_pre_write_conversion]; | |
9692 CHECK_SYMBOL (val); | |
9693 CODING_ATTR_PRE_WRITE (attrs) = val; | |
9694 | |
9695 val = args[coding_arg_default_char]; | |
9696 if (NILP (val)) | |
9697 CODING_ATTR_DEFAULT_CHAR (attrs) = make_number (' '); | |
9698 else | |
9699 { | |
89483 | 9700 CHECK_CHARACTER (val); |
88365 | 9701 CODING_ATTR_DEFAULT_CHAR (attrs) = val; |
9702 } | |
9703 | |
89483 | 9704 val = args[coding_arg_for_unibyte]; |
9705 CODING_ATTR_FOR_UNIBYTE (attrs) = NILP (val) ? Qnil : Qt; | |
9706 | |
88365 | 9707 val = args[coding_arg_plist]; |
9708 CHECK_LIST (val); | |
9709 CODING_ATTR_PLIST (attrs) = val; | |
9710 | |
9711 if (EQ (coding_type, Qcharset)) | |
9712 { | |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9713 /* Generate a lisp vector of 256 elements. Each element is nil, |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9714 integer, or a list of charset IDs. |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9715 |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9716 If Nth element is nil, the byte code N is invalid in this |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9717 coding system. |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9718 |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9719 If Nth element is a number NUM, N is the first byte of a |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9720 charset whose ID is NUM. |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9721 |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9722 If Nth element is a list of charset IDs, N is the first byte |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9723 of one of them. The list is sorted by dimensions of the |
110983 | 9724 charsets. A charset of smaller dimension comes first. */ |
88365 | 9725 val = Fmake_vector (make_number (256), Qnil); |
9726 | |
89653
cbaa9fd1aa5c
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89648
diff
changeset
|
9727 for (tail = charset_list; CONSP (tail); tail = XCDR (tail)) |
88365 | 9728 { |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9729 struct charset *charset = CHARSET_FROM_ID (XFASTINT (XCAR (tail))); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9730 int dim = CHARSET_DIMENSION (charset); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9731 int idx = (dim - 1) * 4; |
89483 | 9732 |
89653
cbaa9fd1aa5c
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89648
diff
changeset
|
9733 if (CHARSET_ASCII_COMPATIBLE_P (charset)) |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9734 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9735 |
88477
5f974cbba7b3
(coding_set_source): Delete the local variable beg_byte.
Kenichi Handa <handa@m17n.org>
parents:
88473
diff
changeset
|
9736 for (i = charset->code_space[idx]; |
5f974cbba7b3
(coding_set_source): Delete the local variable beg_byte.
Kenichi Handa <handa@m17n.org>
parents:
88473
diff
changeset
|
9737 i <= charset->code_space[idx + 1]; i++) |
5f974cbba7b3
(coding_set_source): Delete the local variable beg_byte.
Kenichi Handa <handa@m17n.org>
parents:
88473
diff
changeset
|
9738 { |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9739 Lisp_Object tmp, tmp2; |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9740 int dim2; |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9741 |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9742 tmp = AREF (val, i); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9743 if (NILP (tmp)) |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9744 tmp = XCAR (tail); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9745 else if (NUMBERP (tmp)) |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9746 { |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9747 dim2 = CHARSET_DIMENSION (CHARSET_FROM_ID (XFASTINT (tmp))); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9748 if (dim < dim2) |
88607
18436bf3d6dd
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
88598
diff
changeset
|
9749 tmp = Fcons (XCAR (tail), Fcons (tmp, Qnil)); |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9750 else |
88607
18436bf3d6dd
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
88598
diff
changeset
|
9751 tmp = Fcons (tmp, Fcons (XCAR (tail), Qnil)); |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9752 } |
88477
5f974cbba7b3
(coding_set_source): Delete the local variable beg_byte.
Kenichi Handa <handa@m17n.org>
parents:
88473
diff
changeset
|
9753 else |
88597
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9754 { |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9755 for (tmp2 = tmp; CONSP (tmp2); tmp2 = XCDR (tmp2)) |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9756 { |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9757 dim2 = CHARSET_DIMENSION (CHARSET_FROM_ID (XFASTINT (XCAR (tmp2)))); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9758 if (dim < dim2) |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9759 break; |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9760 } |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9761 if (NILP (tmp2)) |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9762 tmp = nconc2 (tmp, Fcons (XCAR (tail), Qnil)); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9763 else |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9764 { |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9765 XSETCDR (tmp2, Fcons (XCAR (tmp2), XCDR (tmp2))); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9766 XSETCAR (tmp2, XCAR (tail)); |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9767 } |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9768 } |
74b74f59bc09
(decode_coding_charset): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents:
88587
diff
changeset
|
9769 ASET (val, i, tmp); |
88477
5f974cbba7b3
(coding_set_source): Delete the local variable beg_byte.
Kenichi Handa <handa@m17n.org>
parents:
88473
diff
changeset
|
9770 } |
88365 | 9771 } |
9772 ASET (attrs, coding_attr_charset_valids, val); | |
9773 category = coding_category_charset; | |
9774 } | |
9775 else if (EQ (coding_type, Qccl)) | |
9776 { | |
9777 Lisp_Object valids; | |
89483 | 9778 |
88365 | 9779 if (nargs < coding_arg_ccl_max) |
9780 goto short_args; | |
9781 | |
9782 val = args[coding_arg_ccl_decoder]; | |
9783 CHECK_CCL_PROGRAM (val); | |
9784 if (VECTORP (val)) | |
9785 val = Fcopy_sequence (val); | |
9786 ASET (attrs, coding_attr_ccl_decoder, val); | |
9787 | |
9788 val = args[coding_arg_ccl_encoder]; | |
9789 CHECK_CCL_PROGRAM (val); | |
9790 if (VECTORP (val)) | |
9791 val = Fcopy_sequence (val); | |
9792 ASET (attrs, coding_attr_ccl_encoder, val); | |
9793 | |
9794 val = args[coding_arg_ccl_valids]; | |
9795 valids = Fmake_string (make_number (256), make_number (0)); | |
9796 for (tail = val; !NILP (tail); tail = Fcdr (tail)) | |
9797 { | |
89373
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9798 int from, to; |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9799 |
88365 | 9800 val = Fcar (tail); |
9801 if (INTEGERP (val)) | |
89373
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9802 { |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9803 from = to = XINT (val); |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9804 if (from < 0 || from > 255) |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9805 args_out_of_range_3 (val, make_number (0), make_number (255)); |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9806 } |
88365 | 9807 else |
9808 { | |
9809 CHECK_CONS (val); | |
89483 | 9810 CHECK_NATNUM_CAR (val); |
9811 CHECK_NATNUM_CDR (val); | |
88365 | 9812 from = XINT (XCAR (val)); |
89483 | 9813 if (from > 255) |
89373
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9814 args_out_of_range_3 (XCAR (val), |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9815 make_number (0), make_number (255)); |
88365 | 9816 to = XINT (XCDR (val)); |
89373
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9817 if (to < from || to > 255) |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9818 args_out_of_range_3 (XCDR (val), |
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9819 XCAR (val), make_number (255)); |
88365 | 9820 } |
89373
4cc9e57fcabc
(decode_coding_ccl, encode_coding_ccl): Call ccl_driver
Kenichi Handa <handa@m17n.org>
parents:
89331
diff
changeset
|
9821 for (i = from; i <= to; i++) |
89483 | 9822 SSET (valids, i, 1); |
88365 | 9823 } |
9824 ASET (attrs, coding_attr_ccl_valids, valids); | |
89483 | 9825 |
88365 | 9826 category = coding_category_ccl; |
9827 } | |
9828 else if (EQ (coding_type, Qutf_16)) | |
9829 { | |
9830 Lisp_Object bom, endian; | |
9831 | |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9832 CODING_ATTR_ASCII_COMPAT (attrs) = Qnil; |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9833 |
88365 | 9834 if (nargs < coding_arg_utf16_max) |
9835 goto short_args; | |
9836 | |
9837 bom = args[coding_arg_utf16_bom]; | |
9838 if (! NILP (bom) && ! EQ (bom, Qt)) | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
9839 { |
88365 | 9840 CHECK_CONS (bom); |
89483 | 9841 val = XCAR (bom); |
9842 CHECK_CODING_SYSTEM (val); | |
9843 val = XCDR (bom); | |
9844 CHECK_CODING_SYSTEM (val); | |
88365 | 9845 } |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
9846 ASET (attrs, coding_attr_utf_bom, bom); |
88365 | 9847 |
9848 endian = args[coding_arg_utf16_endian]; | |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
9849 CHECK_SYMBOL (endian); |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
9850 if (NILP (endian)) |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
9851 endian = Qbig; |
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
9852 else if (! EQ (endian, Qbig) && ! EQ (endian, Qlittle)) |
89483 | 9853 error ("Invalid endian: %s", SDATA (SYMBOL_NAME (endian))); |
88365 | 9854 ASET (attrs, coding_attr_utf_16_endian, endian); |
9855 | |
9856 category = (CONSP (bom) | |
9857 ? coding_category_utf_16_auto | |
9858 : NILP (bom) | |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
9859 ? (EQ (endian, Qbig) |
88365 | 9860 ? coding_category_utf_16_be_nosig |
9861 : coding_category_utf_16_le_nosig) | |
89420
c3e67ce6ee0f
(Qsignature, Qendian): Delete these variables.
Kenichi Handa <handa@m17n.org>
parents:
89418
diff
changeset
|
9862 : (EQ (endian, Qbig) |
88365 | 9863 ? coding_category_utf_16_be |
9864 : coding_category_utf_16_le)); | |
9865 } | |
9866 else if (EQ (coding_type, Qiso_2022)) | |
9867 { | |
9868 Lisp_Object initial, reg_usage, request, flags; | |
89442
7349f4473e7f
(detected_mask): Delete unused variable.
Kenichi Handa <handa@m17n.org>
parents:
89429
diff
changeset
|
9869 int i; |
88365 | 9870 |
9871 if (nargs < coding_arg_iso2022_max) | |
9872 goto short_args; | |
9873 | |
9874 initial = Fcopy_sequence (args[coding_arg_iso2022_initial]); | |
9875 CHECK_VECTOR (initial); | |
9876 for (i = 0; i < 4; i++) | |
9877 { | |
9878 val = Faref (initial, make_number (i)); | |
9879 if (! NILP (val)) | |
9880 { | |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9881 struct charset *charset; |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9882 |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9883 CHECK_CHARSET_GET_CHARSET (val, charset); |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9884 ASET (initial, i, make_number (CHARSET_ID (charset))); |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9885 if (i == 0 && CHARSET_ASCII_COMPATIBLE_P (charset)) |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9886 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
88365 | 9887 } |
9888 else | |
9889 ASET (initial, i, make_number (-1)); | |
9890 } | |
9891 | |
9892 reg_usage = args[coding_arg_iso2022_reg_usage]; | |
9893 CHECK_CONS (reg_usage); | |
89483 | 9894 CHECK_NUMBER_CAR (reg_usage); |
9895 CHECK_NUMBER_CDR (reg_usage); | |
88365 | 9896 |
9897 request = Fcopy_sequence (args[coding_arg_iso2022_request]); | |
9898 for (tail = request; ! NILP (tail); tail = Fcdr (tail)) | |
9899 { | |
9900 int id; | |
89483 | 9901 Lisp_Object tmp; |
88365 | 9902 |
9903 val = Fcar (tail); | |
9904 CHECK_CONS (val); | |
89483 | 9905 tmp = XCAR (val); |
9906 CHECK_CHARSET_GET_ID (tmp, id); | |
9907 CHECK_NATNUM_CDR (val); | |
88365 | 9908 if (XINT (XCDR (val)) >= 4) |
9909 error ("Invalid graphic register number: %d", XINT (XCDR (val))); | |
89483 | 9910 XSETCAR (val, make_number (id)); |
88365 | 9911 } |
9912 | |
9913 flags = args[coding_arg_iso2022_flags]; | |
9914 CHECK_NATNUM (flags); | |
9915 i = XINT (flags); | |
9916 if (EQ (args[coding_arg_charset_list], Qiso_2022)) | |
9917 flags = make_number (i | CODING_ISO_FLAG_FULL_SUPPORT); | |
9918 | |
9919 ASET (attrs, coding_attr_iso_initial, initial); | |
9920 ASET (attrs, coding_attr_iso_usage, reg_usage); | |
9921 ASET (attrs, coding_attr_iso_request, request); | |
9922 ASET (attrs, coding_attr_iso_flags, flags); | |
9923 setup_iso_safe_charsets (attrs); | |
9924 | |
9925 if (i & CODING_ISO_FLAG_SEVEN_BITS) | |
9926 category = ((i & (CODING_ISO_FLAG_LOCKING_SHIFT | |
9927 | CODING_ISO_FLAG_SINGLE_SHIFT)) | |
9928 ? coding_category_iso_7_else | |
9929 : EQ (args[coding_arg_charset_list], Qiso_2022) | |
9930 ? coding_category_iso_7 | |
9931 : coding_category_iso_7_tight); | |
9932 else | |
9933 { | |
9934 int id = XINT (AREF (initial, 1)); | |
9935 | |
88977
3b05c02eebf2
(Fdefine_coding_system_internal): Fix category setting
Kenichi Handa <handa@m17n.org>
parents:
88950
diff
changeset
|
9936 category = (((i & CODING_ISO_FLAG_LOCKING_SHIFT) |
88365 | 9937 || EQ (args[coding_arg_charset_list], Qiso_2022) |
9938 || id < 0) | |
9939 ? coding_category_iso_8_else | |
9940 : (CHARSET_DIMENSION (CHARSET_FROM_ID (id)) == 1) | |
9941 ? coding_category_iso_8_1 | |
9942 : coding_category_iso_8_2); | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
9943 } |
89227
101ee928c088
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89225
diff
changeset
|
9944 if (category != coding_category_iso_8_1 |
101ee928c088
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89225
diff
changeset
|
9945 && category != coding_category_iso_8_2) |
101ee928c088
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89225
diff
changeset
|
9946 CODING_ATTR_ASCII_COMPAT (attrs) = Qnil; |
88365 | 9947 } |
9948 else if (EQ (coding_type, Qemacs_mule)) | |
9949 { | |
9950 if (EQ (args[coding_arg_charset_list], Qemacs_mule)) | |
9951 ASET (attrs, coding_attr_emacs_mule_full, Qt); | |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9952 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
88365 | 9953 category = coding_category_emacs_mule; |
9954 } | |
9955 else if (EQ (coding_type, Qshift_jis)) | |
9956 { | |
9957 | |
9958 struct charset *charset; | |
9959 | |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
9960 if (XINT (Flength (charset_list)) != 3 |
89739
293c9235be3f
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89732
diff
changeset
|
9961 && XINT (Flength (charset_list)) != 4) |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
9962 error ("There should be three or four charsets"); |
88365 | 9963 |
9964 charset = CHARSET_FROM_ID (XINT (XCAR (charset_list))); | |
9965 if (CHARSET_DIMENSION (charset) != 1) | |
9966 error ("Dimension of charset %s is not one", | |
89483 | 9967 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9968 if (CHARSET_ASCII_COMPATIBLE_P (charset)) |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
9969 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
88365 | 9970 |
9971 charset_list = XCDR (charset_list); | |
9972 charset = CHARSET_FROM_ID (XINT (XCAR (charset_list))); | |
9973 if (CHARSET_DIMENSION (charset) != 1) | |
9974 error ("Dimension of charset %s is not one", | |
89483 | 9975 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
88365 | 9976 |
9977 charset_list = XCDR (charset_list); | |
9978 charset = CHARSET_FROM_ID (XINT (XCAR (charset_list))); | |
9979 if (CHARSET_DIMENSION (charset) != 2) | |
9980 error ("Dimension of charset %s is not two", | |
89483 | 9981 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
88365 | 9982 |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
9983 charset_list = XCDR (charset_list); |
89740
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9984 if (! NILP (charset_list)) |
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9985 { |
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9986 charset = CHARSET_FROM_ID (XINT (XCAR (charset_list))); |
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9987 if (CHARSET_DIMENSION (charset) != 2) |
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9988 error ("Dimension of charset %s is not two", |
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9989 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
78c1fd14ed42
(Fdefine_coding_system_internal): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89739
diff
changeset
|
9990 } |
89732
8acde12aba89
(get_translation_table): New function.
Kenichi Handa <handa@m17n.org>
parents:
89730
diff
changeset
|
9991 |
88365 | 9992 category = coding_category_sjis; |
9993 Vsjis_coding_system = name; | |
9994 } | |
9995 else if (EQ (coding_type, Qbig5)) | |
9996 { | |
9997 struct charset *charset; | |
9998 | |
9999 if (XINT (Flength (charset_list)) != 2) | |
10000 error ("There should be just two charsets"); | |
10001 | |
10002 charset = CHARSET_FROM_ID (XINT (XCAR (charset_list))); | |
10003 if (CHARSET_DIMENSION (charset) != 1) | |
10004 error ("Dimension of charset %s is not one", | |
89483 | 10005 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10006 if (CHARSET_ASCII_COMPATIBLE_P (charset)) |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10007 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
88365 | 10008 |
10009 charset_list = XCDR (charset_list); | |
10010 charset = CHARSET_FROM_ID (XINT (XCAR (charset_list))); | |
10011 if (CHARSET_DIMENSION (charset) != 2) | |
10012 error ("Dimension of charset %s is not two", | |
89483 | 10013 SDATA (SYMBOL_NAME (CHARSET_NAME (charset)))); |
88365 | 10014 |
10015 category = coding_category_big5; | |
10016 Vbig5_coding_system = name; | |
10017 } | |
10018 else if (EQ (coding_type, Qraw_text)) | |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10019 { |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10020 category = coding_category_raw_text; |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10021 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10022 } |
88365 | 10023 else if (EQ (coding_type, Qutf_8)) |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10024 { |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10025 Lisp_Object bom; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10026 |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10027 CODING_ATTR_ASCII_COMPAT (attrs) = Qt; |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10028 |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10029 if (nargs < coding_arg_utf8_max) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10030 goto short_args; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10031 |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10032 bom = args[coding_arg_utf8_bom]; |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10033 if (! NILP (bom) && ! EQ (bom, Qt)) |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10034 { |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10035 CHECK_CONS (bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10036 val = XCAR (bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10037 CHECK_CODING_SYSTEM (val); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10038 val = XCDR (bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10039 CHECK_CODING_SYSTEM (val); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10040 } |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10041 ASET (attrs, coding_attr_utf_bom, bom); |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10042 |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10043 category = (CONSP (bom) ? coding_category_utf_8_auto |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10044 : NILP (bom) ? coding_category_utf_8_nosig |
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10045 : coding_category_utf_8_sig); |
89225
32058afc72e2
(detect_coding_charset): If only ASCII bytes are found, return 0.
Kenichi Handa <handa@m17n.org>
parents:
89221
diff
changeset
|
10046 } |
88365 | 10047 else if (EQ (coding_type, Qundecided)) |
10048 category = coding_category_undecided; | |
10049 else | |
10050 error ("Invalid coding system type: %s", | |
89483 | 10051 SDATA (SYMBOL_NAME (coding_type))); |
88365 | 10052 |
10053 CODING_ATTR_CATEGORY (attrs) = make_number (category); | |
89468
7dbbe692f70c
* coding.c (QCcategory): New variable.
Kenichi Handa <handa@m17n.org>
parents:
89467
diff
changeset
|
10054 CODING_ATTR_PLIST (attrs) |
7dbbe692f70c
* coding.c (QCcategory): New variable.
Kenichi Handa <handa@m17n.org>
parents:
89467
diff
changeset
|
10055 = Fcons (QCcategory, Fcons (AREF (Vcoding_category_table, category), |
7dbbe692f70c
* coding.c (QCcategory): New variable.
Kenichi Handa <handa@m17n.org>
parents:
89467
diff
changeset
|
10056 CODING_ATTR_PLIST (attrs))); |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10057 CODING_ATTR_PLIST (attrs) |
93877
62d97ebb13a9
* coding.c (detect_coding_emacs_mule)
Michael Albinus <michael.albinus@gmx.de>
parents:
93595
diff
changeset
|
10058 = Fcons (QCascii_compatible_p, |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10059 Fcons (CODING_ATTR_ASCII_COMPAT (attrs), |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10060 CODING_ATTR_PLIST (attrs))); |
88365 | 10061 |
10062 eol_type = args[coding_arg_eol_type]; | |
10063 if (! NILP (eol_type) | |
10064 && ! EQ (eol_type, Qunix) | |
10065 && ! EQ (eol_type, Qdos) | |
10066 && ! EQ (eol_type, Qmac)) | |
10067 error ("Invalid eol-type"); | |
10068 | |
10069 aliases = Fcons (name, Qnil); | |
10070 | |
10071 if (NILP (eol_type)) | |
10072 { | |
10073 eol_type = make_subsidiaries (name); | |
10074 for (i = 0; i < 3; i++) | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
10075 { |
88365 | 10076 Lisp_Object this_spec, this_name, this_aliases, this_eol_type; |
10077 | |
10078 this_name = AREF (eol_type, i); | |
10079 this_aliases = Fcons (this_name, Qnil); | |
10080 this_eol_type = (i == 0 ? Qunix : i == 1 ? Qdos : Qmac); | |
10081 this_spec = Fmake_vector (make_number (3), attrs); | |
10082 ASET (this_spec, 1, this_aliases); | |
10083 ASET (this_spec, 2, this_eol_type); | |
10084 Fputhash (this_name, this_spec, Vcoding_system_hash_table); | |
10085 Vcoding_system_list = Fcons (this_name, Vcoding_system_list); | |
90289
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10086 val = Fassoc (Fsymbol_name (this_name), Vcoding_system_alist); |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10087 if (NILP (val)) |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10088 Vcoding_system_alist |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10089 = Fcons (Fcons (Fsymbol_name (this_name), Qnil), |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10090 Vcoding_system_alist); |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
10091 } |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10092 } |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
10093 |
88365 | 10094 spec_vec = Fmake_vector (make_number (3), attrs); |
10095 ASET (spec_vec, 1, aliases); | |
10096 ASET (spec_vec, 2, eol_type); | |
10097 | |
10098 Fputhash (name, spec_vec, Vcoding_system_hash_table); | |
10099 Vcoding_system_list = Fcons (name, Vcoding_system_list); | |
90289
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10100 val = Fassoc (Fsymbol_name (name), Vcoding_system_alist); |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10101 if (NILP (val)) |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10102 Vcoding_system_alist = Fcons (Fcons (Fsymbol_name (name), Qnil), |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10103 Vcoding_system_alist); |
88365 | 10104 |
10105 { | |
10106 int id = coding_categories[category].id; | |
10107 | |
10108 if (id < 0 || EQ (name, CODING_ID_NAME (id))) | |
10109 setup_coding_system (name, &coding_categories[category]); | |
10110 } | |
10111 | |
10112 return Qnil; | |
10113 | |
10114 short_args: | |
10115 return Fsignal (Qwrong_number_of_arguments, | |
10116 Fcons (intern ("define-coding-system-internal"), | |
10117 make_number (nargs))); | |
10118 } | |
10119 | |
89571
242f2cc0134b
(Fdefine_coding_system_alias): Update Vcoding_system_list.
Kenichi Handa <handa@m17n.org>
parents:
89562
diff
changeset
|
10120 |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10121 DEFUN ("coding-system-put", Fcoding_system_put, Scoding_system_put, |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10122 3, 3, 0, |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10123 doc: /* Change value in CODING-SYSTEM's property list PROP to VAL. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
10124 (Lisp_Object coding_system, Lisp_Object prop, Lisp_Object val) |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10125 { |
89924
7d0f6da3ea6e
(detect_coding): Delete unused variables.
Kenichi Handa <handa@m17n.org>
parents:
89917
diff
changeset
|
10126 Lisp_Object spec, attrs; |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10127 |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10128 CHECK_CODING_SYSTEM_GET_SPEC (coding_system, spec); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10129 attrs = AREF (spec, 0); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10130 if (EQ (prop, QCmnemonic)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10131 { |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10132 if (! STRINGP (val)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10133 CHECK_CHARACTER (val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10134 CODING_ATTR_MNEMONIC (attrs) = val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10135 } |
100303
3e044fa54e4f
* coding.c (QCdefault_char): Rename from QCdefalut_char.
Juanma Barranquero <lekktu@gmail.com>
parents:
100262
diff
changeset
|
10136 else if (EQ (prop, QCdefault_char)) |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10137 { |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10138 if (NILP (val)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10139 val = make_number (' '); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10140 else |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10141 CHECK_CHARACTER (val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10142 CODING_ATTR_DEFAULT_CHAR (attrs) = val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10143 } |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10144 else if (EQ (prop, QCdecode_translation_table)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10145 { |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10146 if (! CHAR_TABLE_P (val) && ! CONSP (val)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10147 CHECK_SYMBOL (val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10148 CODING_ATTR_DECODE_TBL (attrs) = val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10149 } |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10150 else if (EQ (prop, QCencode_translation_table)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10151 { |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10152 if (! CHAR_TABLE_P (val) && ! CONSP (val)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10153 CHECK_SYMBOL (val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10154 CODING_ATTR_ENCODE_TBL (attrs) = val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10155 } |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10156 else if (EQ (prop, QCpost_read_conversion)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10157 { |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10158 CHECK_SYMBOL (val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10159 CODING_ATTR_POST_READ (attrs) = val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10160 } |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10161 else if (EQ (prop, QCpre_write_conversion)) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10162 { |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10163 CHECK_SYMBOL (val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10164 CODING_ATTR_PRE_WRITE (attrs) = val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10165 } |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10166 else if (EQ (prop, QCascii_compatible_p)) |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10167 { |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10168 CODING_ATTR_ASCII_COMPAT (attrs) = val; |
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10169 } |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10170 |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10171 CODING_ATTR_PLIST (attrs) |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10172 = Fplist_put (CODING_ATTR_PLIST (attrs), prop, val); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10173 return val; |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10174 } |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10175 |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10176 |
88365 | 10177 DEFUN ("define-coding-system-alias", Fdefine_coding_system_alias, |
10178 Sdefine_coding_system_alias, 2, 2, 0, | |
10179 doc: /* Define ALIAS as an alias for CODING-SYSTEM. */) | |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
10180 (Lisp_Object alias, Lisp_Object coding_system) |
88365 | 10181 { |
90289
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10182 Lisp_Object spec, aliases, eol_type, val; |
88365 | 10183 |
10184 CHECK_SYMBOL (alias); | |
10185 CHECK_CODING_SYSTEM_GET_SPEC (coding_system, spec); | |
10186 aliases = AREF (spec, 1); | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
10187 /* ALIASES should be a list of length more than zero, and the first |
89571
242f2cc0134b
(Fdefine_coding_system_alias): Update Vcoding_system_list.
Kenichi Handa <handa@m17n.org>
parents:
89562
diff
changeset
|
10188 element is a base coding system. Append ALIAS at the tail of the |
242f2cc0134b
(Fdefine_coding_system_alias): Update Vcoding_system_list.
Kenichi Handa <handa@m17n.org>
parents:
89562
diff
changeset
|
10189 list. */ |
88365 | 10190 while (!NILP (XCDR (aliases))) |
10191 aliases = XCDR (aliases); | |
89483 | 10192 XSETCDR (aliases, Fcons (alias, Qnil)); |
88365 | 10193 |
10194 eol_type = AREF (spec, 2); | |
10195 if (VECTORP (eol_type)) | |
10196 { | |
10197 Lisp_Object subsidiaries; | |
10198 int i; | |
10199 | |
10200 subsidiaries = make_subsidiaries (alias); | |
10201 for (i = 0; i < 3; i++) | |
10202 Fdefine_coding_system_alias (AREF (subsidiaries, i), | |
10203 AREF (eol_type, i)); | |
10204 } | |
10205 | |
10206 Fputhash (alias, spec, Vcoding_system_hash_table); | |
89571
242f2cc0134b
(Fdefine_coding_system_alias): Update Vcoding_system_list.
Kenichi Handa <handa@m17n.org>
parents:
89562
diff
changeset
|
10207 Vcoding_system_list = Fcons (alias, Vcoding_system_list); |
90289
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10208 val = Fassoc (Fsymbol_name (alias), Vcoding_system_alist); |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10209 if (NILP (val)) |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10210 Vcoding_system_alist = Fcons (Fcons (Fsymbol_name (alias), Qnil), |
72d8a45f6c9f
(Fdefine_coding_system_internal): Avoid a duplicated
Kenichi Handa <handa@m17n.org>
parents:
90272
diff
changeset
|
10211 Vcoding_system_alist); |
88365 | 10212 |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10213 return Qnil; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10214 } |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10215 |
88365 | 10216 DEFUN ("coding-system-base", Fcoding_system_base, Scoding_system_base, |
10217 1, 1, 0, | |
10218 doc: /* Return the base of CODING-SYSTEM. | |
88645 | 10219 Any alias or subsidiary coding system is not a base coding system. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
10220 (Lisp_Object coding_system) |
88365 | 10221 { |
10222 Lisp_Object spec, attrs; | |
10223 | |
10224 if (NILP (coding_system)) | |
10225 return (Qno_conversion); | |
10226 CHECK_CODING_SYSTEM_GET_SPEC (coding_system, spec); | |
10227 attrs = AREF (spec, 0); | |
10228 return CODING_ATTR_BASE_NAME (attrs); | |
10229 } | |
10230 | |
10231 DEFUN ("coding-system-plist", Fcoding_system_plist, Scoding_system_plist, | |
10232 1, 1, 0, | |
10233 doc: "Return the property list of CODING-SYSTEM.") | |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
10234 (Lisp_Object coding_system) |
49539
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10235 { |
88365 | 10236 Lisp_Object spec, attrs; |
10237 | |
10238 if (NILP (coding_system)) | |
10239 coding_system = Qno_conversion; | |
10240 CHECK_CODING_SYSTEM_GET_SPEC (coding_system, spec); | |
10241 attrs = AREF (spec, 0); | |
10242 return CODING_ATTR_PLIST (attrs); | |
10243 } | |
10244 | |
10245 | |
10246 DEFUN ("coding-system-aliases", Fcoding_system_aliases, Scoding_system_aliases, | |
10247 1, 1, 0, | |
88645 | 10248 doc: /* Return the list of aliases of CODING-SYSTEM. */) |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
10249 (Lisp_Object coding_system) |
88365 | 10250 { |
10251 Lisp_Object spec; | |
10252 | |
10253 if (NILP (coding_system)) | |
10254 coding_system = Qno_conversion; | |
10255 CHECK_CODING_SYSTEM_GET_SPEC (coding_system, spec); | |
88645 | 10256 return AREF (spec, 1); |
88365 | 10257 } |
10258 | |
10259 DEFUN ("coding-system-eol-type", Fcoding_system_eol_type, | |
10260 Scoding_system_eol_type, 1, 1, 0, | |
10261 doc: /* Return eol-type of CODING-SYSTEM. | |
95088
524350e4961c
(Fcoding_system_p): Rename argument to match docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94963
diff
changeset
|
10262 An eol-type is an integer 0, 1, 2, or a vector of coding systems. |
88365 | 10263 |
10264 Integer values 0, 1, and 2 indicate a format of end-of-line; LF, CRLF, | |
10265 and CR respectively. | |
10266 | |
10267 A vector value indicates that a format of end-of-line should be | |
10268 detected automatically. Nth element of the vector is the subsidiary | |
10269 coding system whose eol-type is N. */) | |
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109165
diff
changeset
|
10270 (Lisp_Object coding_system) |
88365 | 10271 { |
10272 Lisp_Object spec, eol_type; | |
10273 int n; | |
10274 | |
10275 if (NILP (coding_system)) | |
10276 coding_system = Qno_conversion; | |
10277 if (! CODING_SYSTEM_P (coding_system)) | |
10278 return Qnil; | |
10279 spec = CODING_SYSTEM_SPEC (coding_system); | |
10280 eol_type = AREF (spec, 2); | |
10281 if (VECTORP (eol_type)) | |
10282 return Fcopy_sequence (eol_type); | |
10283 n = EQ (eol_type, Qunix) ? 0 : EQ (eol_type, Qdos) ? 1 : 2; | |
10284 return make_number (n); | |
49539
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10285 } |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10286 |
17052 | 10287 #endif /* emacs */ |
10288 | |
10289 | |
22874
b133f07a76db
(Qvalid_codes): New variable.
Kenichi Handa <handa@m17n.org>
parents:
22812
diff
changeset
|
10290 /*** 9. Post-amble ***/ |
17052 | 10291 |
21514 | 10292 void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
10293 init_coding_once (void) |
17052 | 10294 { |
10295 int i; | |
10296 | |
88365 | 10297 for (i = 0; i < coding_category_max; i++) |
10298 { | |
10299 coding_categories[i].id = -1; | |
10300 coding_priorities[i] = i; | |
10301 } | |
17052 | 10302 |
10303 /* ISO2022 specific initialize routine. */ | |
10304 for (i = 0; i < 0x20; i++) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
10305 iso_code_class[i] = ISO_control_0; |
17052 | 10306 for (i = 0x21; i < 0x7F; i++) |
10307 iso_code_class[i] = ISO_graphic_plane_0; | |
10308 for (i = 0x80; i < 0xA0; i++) | |
29005
b396df3a5181
(ONE_MORE_BYTE, TWO_MORE_BYTES): Set coding->resutl to
Kenichi Handa <handa@m17n.org>
parents:
28512
diff
changeset
|
10309 iso_code_class[i] = ISO_control_1; |
17052 | 10310 for (i = 0xA1; i < 0xFF; i++) |
10311 iso_code_class[i] = ISO_graphic_plane_1; | |
10312 iso_code_class[0x20] = iso_code_class[0x7F] = ISO_0x20_or_0x7F; | |
10313 iso_code_class[0xA0] = iso_code_class[0xFF] = ISO_0xA0_or_0xFF; | |
10314 iso_code_class[ISO_CODE_SO] = ISO_shift_out; | |
10315 iso_code_class[ISO_CODE_SI] = ISO_shift_in; | |
10316 iso_code_class[ISO_CODE_SS2_7] = ISO_single_shift_2_7; | |
10317 iso_code_class[ISO_CODE_ESC] = ISO_escape; | |
10318 iso_code_class[ISO_CODE_SS2] = ISO_single_shift_2; | |
10319 iso_code_class[ISO_CODE_SS3] = ISO_single_shift_3; | |
10320 iso_code_class[ISO_CODE_CSI] = ISO_control_sequence_introducer; | |
10321 | |
88365 | 10322 for (i = 0; i < 256; i++) |
10323 { | |
10324 emacs_mule_bytes[i] = 1; | |
10325 } | |
88876
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
10326 emacs_mule_bytes[EMACS_MULE_LEADING_CODE_PRIVATE_11] = 3; |
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
10327 emacs_mule_bytes[EMACS_MULE_LEADING_CODE_PRIVATE_12] = 3; |
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
10328 emacs_mule_bytes[EMACS_MULE_LEADING_CODE_PRIVATE_21] = 4; |
af9012fdad56
(LEADING_CODE_PRIVATE_11, LEADING_CODE_PRIVATE_12,
Kenichi Handa <handa@m17n.org>
parents:
88862
diff
changeset
|
10329 emacs_mule_bytes[EMACS_MULE_LEADING_CODE_PRIVATE_22] = 4; |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10330 } |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10331 |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10332 #ifdef emacs |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10333 |
21514 | 10334 void |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
10335 syms_of_coding (void) |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10336 { |
88365 | 10337 staticpro (&Vcoding_system_hash_table); |
89483 | 10338 { |
10339 Lisp_Object args[2]; | |
10340 args[0] = QCtest; | |
10341 args[1] = Qeq; | |
10342 Vcoding_system_hash_table = Fmake_hash_table (2, args); | |
10343 } | |
88365 | 10344 |
10345 staticpro (&Vsjis_coding_system); | |
10346 Vsjis_coding_system = Qnil; | |
10347 | |
10348 staticpro (&Vbig5_coding_system); | |
10349 Vbig5_coding_system = Qnil; | |
10350 | |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
10351 staticpro (&Vcode_conversion_reused_workbuf); |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
10352 Vcode_conversion_reused_workbuf = Qnil; |
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
10353 |
58637
ff8a37b5299b
(Vcode_conversion_workbuf_name): New variable.
Kenichi Handa <handa@m17n.org>
parents:
58502
diff
changeset
|
10354 staticpro (&Vcode_conversion_workbuf_name); |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10355 Vcode_conversion_workbuf_name = make_pure_c_string (" *code-conversion-work*"); |
58637
ff8a37b5299b
(Vcode_conversion_workbuf_name): New variable.
Kenichi Handa <handa@m17n.org>
parents:
58502
diff
changeset
|
10356 |
89665
9010cefe8d29
(enum iso_code_class_type): Delete ISO_carriage_return.
Kenichi Handa <handa@m17n.org>
parents:
89653
diff
changeset
|
10357 reused_workbuf_in_use = 0; |
88365 | 10358 |
10359 DEFSYM (Qcharset, "charset"); | |
10360 DEFSYM (Qtarget_idx, "target-idx"); | |
10361 DEFSYM (Qcoding_system_history, "coding-system-history"); | |
19750
95e4e1cba6ac
(Qcoding_system_history): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
19747
diff
changeset
|
10362 Fset (Qcoding_system_history, Qnil); |
95e4e1cba6ac
(Qcoding_system_history): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
19747
diff
changeset
|
10363 |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10364 /* Target FILENAME is the first argument. */ |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10365 Fput (Qinsert_file_contents, Qtarget_idx, make_number (0)); |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10366 /* Target FILENAME is the third argument. */ |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10367 Fput (Qwrite_region, Qtarget_idx, make_number (2)); |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10368 |
88365 | 10369 DEFSYM (Qcall_process, "call-process"); |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10370 /* Target PROGRAM is the first argument. */ |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10371 Fput (Qcall_process, Qtarget_idx, make_number (0)); |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10372 |
88365 | 10373 DEFSYM (Qcall_process_region, "call-process-region"); |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10374 /* Target PROGRAM is the third argument. */ |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10375 Fput (Qcall_process_region, Qtarget_idx, make_number (2)); |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10376 |
88365 | 10377 DEFSYM (Qstart_process, "start-process"); |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10378 /* Target PROGRAM is the third argument. */ |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10379 Fput (Qstart_process, Qtarget_idx, make_number (2)); |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10380 |
88365 | 10381 DEFSYM (Qopen_network_stream, "open-network-stream"); |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10382 /* Target SERVICE is the fourth argument. */ |
17119
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10383 Fput (Qopen_network_stream, Qtarget_idx, make_number (3)); |
2cfb31c15ced
(create_process, Fopen_network_stream): Typo in indexes
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
10384 |
88365 | 10385 DEFSYM (Qcoding_system, "coding-system"); |
10386 DEFSYM (Qcoding_aliases, "coding-aliases"); | |
10387 | |
10388 DEFSYM (Qeol_type, "eol-type"); | |
10389 DEFSYM (Qunix, "unix"); | |
10390 DEFSYM (Qdos, "dos"); | |
10391 | |
10392 DEFSYM (Qbuffer_file_coding_system, "buffer-file-coding-system"); | |
10393 DEFSYM (Qpost_read_conversion, "post-read-conversion"); | |
10394 DEFSYM (Qpre_write_conversion, "pre-write-conversion"); | |
10395 DEFSYM (Qdefault_char, "default-char"); | |
10396 DEFSYM (Qundecided, "undecided"); | |
10397 DEFSYM (Qno_conversion, "no-conversion"); | |
10398 DEFSYM (Qraw_text, "raw-text"); | |
10399 | |
10400 DEFSYM (Qiso_2022, "iso-2022"); | |
10401 | |
10402 DEFSYM (Qutf_8, "utf-8"); | |
89483 | 10403 DEFSYM (Qutf_8_emacs, "utf-8-emacs"); |
88365 | 10404 |
10405 DEFSYM (Qutf_16, "utf-16"); | |
10406 DEFSYM (Qbig, "big"); | |
10407 DEFSYM (Qlittle, "little"); | |
10408 | |
10409 DEFSYM (Qshift_jis, "shift-jis"); | |
10410 DEFSYM (Qbig5, "big5"); | |
10411 | |
10412 DEFSYM (Qcoding_system_p, "coding-system-p"); | |
10413 | |
10414 DEFSYM (Qcoding_system_error, "coding-system-error"); | |
17052 | 10415 Fput (Qcoding_system_error, Qerror_conditions, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10416 pure_cons (Qcoding_system_error, pure_cons (Qerror, Qnil))); |
17052 | 10417 Fput (Qcoding_system_error, Qerror_message, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10418 make_pure_c_string ("Invalid coding system")); |
17052 | 10419 |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
10420 /* Intern this now in case it isn't already done. |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
10421 Setting this variable twice is harmless. |
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
10422 But don't staticpro it here--that is done in alloc.c. */ |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10423 Qchar_table_extra_slots = intern_c_string ("char-table-extra-slots"); |
88365 | 10424 |
10425 DEFSYM (Qtranslation_table, "translation-table"); | |
89856
18b52da60a76
(get_translation): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
89852
diff
changeset
|
10426 Fput (Qtranslation_table, Qchar_table_extra_slots, make_number (2)); |
88365 | 10427 DEFSYM (Qtranslation_table_id, "translation-table-id"); |
10428 DEFSYM (Qtranslation_table_for_decode, "translation-table-for-decode"); | |
10429 DEFSYM (Qtranslation_table_for_encode, "translation-table-for-encode"); | |
10430 | |
10431 DEFSYM (Qvalid_codes, "valid-codes"); | |
10432 | |
10433 DEFSYM (Qemacs_mule, "emacs-mule"); | |
10434 | |
89468
7dbbe692f70c
* coding.c (QCcategory): New variable.
Kenichi Handa <handa@m17n.org>
parents:
89467
diff
changeset
|
10435 DEFSYM (QCcategory, ":category"); |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10436 DEFSYM (QCmnemonic, ":mnemonic"); |
100303
3e044fa54e4f
* coding.c (QCdefault_char): Rename from QCdefalut_char.
Juanma Barranquero <lekktu@gmail.com>
parents:
100262
diff
changeset
|
10437 DEFSYM (QCdefault_char, ":default-char"); |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10438 DEFSYM (QCdecode_translation_table, ":decode-translation-table"); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10439 DEFSYM (QCencode_translation_table, ":encode-translation-table"); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10440 DEFSYM (QCpost_read_conversion, ":post-read-conversion"); |
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10441 DEFSYM (QCpre_write_conversion, ":pre-write-conversion"); |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10442 DEFSYM (QCascii_compatible_p, ":ascii-compatible-p"); |
89468
7dbbe692f70c
* coding.c (QCcategory): New variable.
Kenichi Handa <handa@m17n.org>
parents:
89467
diff
changeset
|
10443 |
88365 | 10444 Vcoding_category_table |
10445 = Fmake_vector (make_number (coding_category_max), Qnil); | |
10446 staticpro (&Vcoding_category_table); | |
10447 /* Followings are target of code detection. */ | |
10448 ASET (Vcoding_category_table, coding_category_iso_7, | |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10449 intern_c_string ("coding-category-iso-7")); |
88365 | 10450 ASET (Vcoding_category_table, coding_category_iso_7_tight, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10451 intern_c_string ("coding-category-iso-7-tight")); |
88365 | 10452 ASET (Vcoding_category_table, coding_category_iso_8_1, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10453 intern_c_string ("coding-category-iso-8-1")); |
88365 | 10454 ASET (Vcoding_category_table, coding_category_iso_8_2, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10455 intern_c_string ("coding-category-iso-8-2")); |
88365 | 10456 ASET (Vcoding_category_table, coding_category_iso_7_else, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10457 intern_c_string ("coding-category-iso-7-else")); |
88365 | 10458 ASET (Vcoding_category_table, coding_category_iso_8_else, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10459 intern_c_string ("coding-category-iso-8-else")); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10460 ASET (Vcoding_category_table, coding_category_utf_8_auto, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10461 intern_c_string ("coding-category-utf-8-auto")); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10462 ASET (Vcoding_category_table, coding_category_utf_8_nosig, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10463 intern_c_string ("coding-category-utf-8")); |
95397
c99f0a16c077
(CODING_UTF_8_BOM): New macro.
Kenichi Handa <handa@m17n.org>
parents:
95356
diff
changeset
|
10464 ASET (Vcoding_category_table, coding_category_utf_8_sig, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10465 intern_c_string ("coding-category-utf-8-sig")); |
88365 | 10466 ASET (Vcoding_category_table, coding_category_utf_16_be, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10467 intern_c_string ("coding-category-utf-16-be")); |
89467
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10468 ASET (Vcoding_category_table, coding_category_utf_16_auto, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10469 intern_c_string ("coding-category-utf-16-auto")); |
88365 | 10470 ASET (Vcoding_category_table, coding_category_utf_16_le, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10471 intern_c_string ("coding-category-utf-16-le")); |
88365 | 10472 ASET (Vcoding_category_table, coding_category_utf_16_be_nosig, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10473 intern_c_string ("coding-category-utf-16-be-nosig")); |
88365 | 10474 ASET (Vcoding_category_table, coding_category_utf_16_le_nosig, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10475 intern_c_string ("coding-category-utf-16-le-nosig")); |
88365 | 10476 ASET (Vcoding_category_table, coding_category_charset, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10477 intern_c_string ("coding-category-charset")); |
88365 | 10478 ASET (Vcoding_category_table, coding_category_sjis, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10479 intern_c_string ("coding-category-sjis")); |
88365 | 10480 ASET (Vcoding_category_table, coding_category_big5, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10481 intern_c_string ("coding-category-big5")); |
88365 | 10482 ASET (Vcoding_category_table, coding_category_ccl, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10483 intern_c_string ("coding-category-ccl")); |
88365 | 10484 ASET (Vcoding_category_table, coding_category_emacs_mule, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10485 intern_c_string ("coding-category-emacs-mule")); |
88365 | 10486 /* Followings are NOT target of code detection. */ |
10487 ASET (Vcoding_category_table, coding_category_raw_text, | |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10488 intern_c_string ("coding-category-raw-text")); |
88365 | 10489 ASET (Vcoding_category_table, coding_category_undecided, |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10490 intern_c_string ("coding-category-undecided")); |
88365 | 10491 |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10492 DEFSYM (Qinsufficient_source, "insufficient-source"); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10493 DEFSYM (Qinconsistent_eol, "inconsistent-eol"); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10494 DEFSYM (Qinvalid_source, "invalid-source"); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10495 DEFSYM (Qinterrupted, "interrupted"); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10496 DEFSYM (Qinsufficient_memory, "insufficient-memory"); |
90272
f1df126ec7de
Sync to HEAD for handling autoload-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
90263
diff
changeset
|
10497 DEFSYM (Qcoding_system_define_form, "coding-system-define-form"); |
52794
f4d906e31662
(Qcoding_system_define_form): New variable.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
10498 |
17052 | 10499 defsubr (&Scoding_system_p); |
10500 defsubr (&Sread_coding_system); | |
10501 defsubr (&Sread_non_nil_coding_system); | |
10502 defsubr (&Scheck_coding_system); | |
10503 defsubr (&Sdetect_coding_region); | |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10504 defsubr (&Sdetect_coding_string); |
30487
6165da9c89c6
(Qsafe_charsets): This variable deleted.
Kenichi Handa <handa@m17n.org>
parents:
30384
diff
changeset
|
10505 defsubr (&Sfind_coding_systems_region_internal); |
46859
a26dd8891732
(unencodable_char_position): New function.
Kenichi Handa <handa@m17n.org>
parents:
46839
diff
changeset
|
10506 defsubr (&Sunencodable_char_position); |
88365 | 10507 defsubr (&Scheck_coding_systems_region); |
17052 | 10508 defsubr (&Sdecode_coding_region); |
10509 defsubr (&Sencode_coding_region); | |
10510 defsubr (&Sdecode_coding_string); | |
10511 defsubr (&Sencode_coding_string); | |
10512 defsubr (&Sdecode_sjis_char); | |
10513 defsubr (&Sencode_sjis_char); | |
10514 defsubr (&Sdecode_big5_char); | |
10515 defsubr (&Sencode_big5_char); | |
18002
a14261786239
(encode_invocation_designation): Use macro
Kenichi Handa <handa@m17n.org>
parents:
17835
diff
changeset
|
10516 defsubr (&Sset_terminal_coding_system_internal); |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
10517 defsubr (&Sset_safe_terminal_coding_system_internal); |
17052 | 10518 defsubr (&Sterminal_coding_system); |
18002
a14261786239
(encode_invocation_designation): Use macro
Kenichi Handa <handa@m17n.org>
parents:
17835
diff
changeset
|
10519 defsubr (&Sset_keyboard_coding_system_internal); |
17052 | 10520 defsubr (&Skeyboard_coding_system); |
18536
69c0e220b626
(Vstandard_character_unification_table_for_decode):
Kenichi Handa <handa@m17n.org>
parents:
18523
diff
changeset
|
10521 defsubr (&Sfind_operation_coding_system); |
88365 | 10522 defsubr (&Sset_coding_system_priority); |
49539
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10523 defsubr (&Sdefine_coding_system_internal); |
88365 | 10524 defsubr (&Sdefine_coding_system_alias); |
89759
d11866e9fbf4
(QCmnemonic, QCdefalut_char)
Kenichi Handa <handa@m17n.org>
parents:
89740
diff
changeset
|
10525 defsubr (&Scoding_system_put); |
88365 | 10526 defsubr (&Scoding_system_base); |
10527 defsubr (&Scoding_system_plist); | |
10528 defsubr (&Scoding_system_aliases); | |
10529 defsubr (&Scoding_system_eol_type); | |
10530 defsubr (&Scoding_system_priority_list); | |
17052 | 10531 |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
10532 DEFVAR_LISP ("coding-system-list", &Vcoding_system_list, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10533 doc: /* List of coding systems. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10534 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10535 Do not alter the value of this variable manually. This variable should be |
88365 | 10536 updated by the functions `define-coding-system' and |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10537 `define-coding-system-alias'. */); |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
10538 Vcoding_system_list = Qnil; |
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
10539 |
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
10540 DEFVAR_LISP ("coding-system-alist", &Vcoding_system_alist, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10541 doc: /* Alist of coding system names. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10542 Each element is one element list of coding system name. |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10543 This variable is given to `completing-read' as COLLECTION argument. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10544 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10545 Do not alter the value of this variable manually. This variable should be |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10546 updated by the functions `make-coding-system' and |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10547 `define-coding-system-alias'. */); |
20105
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
10548 Vcoding_system_alist = Qnil; |
c017642863c2
(Qcoding_system_spec): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
19824
diff
changeset
|
10549 |
17052 | 10550 DEFVAR_LISP ("coding-category-list", &Vcoding_category_list, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10551 doc: /* List of coding-categories (symbols) ordered by priority. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10552 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10553 On detecting a coding system, Emacs tries code detection algorithms |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10554 associated with each coding-category one by one in this order. When |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10555 one algorithm agrees with a byte sequence of source text, the coding |
60608
4b80e9c28e8f
(syms_of_coding): Docstring of coding-category-list fixed.
Kenichi Handa <handa@m17n.org>
parents:
60031
diff
changeset
|
10556 system bound to the corresponding coding-category is selected. |
4b80e9c28e8f
(syms_of_coding): Docstring of coding-category-list fixed.
Kenichi Handa <handa@m17n.org>
parents:
60031
diff
changeset
|
10557 |
111402
435e622dd41e
Refer to set-coding-system-priority instead of the obsolete
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
111237
diff
changeset
|
10558 Don't modify this variable directly, but use `set-coding-system-priority'. */); |
17052 | 10559 { |
10560 int i; | |
10561 | |
10562 Vcoding_category_list = Qnil; | |
88365 | 10563 for (i = coding_category_max - 1; i >= 0; i--) |
17052 | 10564 Vcoding_category_list |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10565 = Fcons (XVECTOR (Vcoding_category_table)->contents[i], |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10566 Vcoding_category_list); |
17052 | 10567 } |
10568 | |
10569 DEFVAR_LISP ("coding-system-for-read", &Vcoding_system_for_read, | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10570 doc: /* Specify the coding system for read operations. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10571 It is useful to bind this variable with `let', but do not set it globally. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10572 If the value is a coding system, it is used for decoding on read operation. |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10573 If not, an appropriate element is used from one of the coding system alists. |
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10574 There are three such tables: `file-coding-system-alist', |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10575 `process-coding-system-alist', and `network-coding-system-alist'. */); |
17052 | 10576 Vcoding_system_for_read = Qnil; |
10577 | |
10578 DEFVAR_LISP ("coding-system-for-write", &Vcoding_system_for_write, | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10579 doc: /* Specify the coding system for write operations. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10580 Programs bind this variable with `let', but you should not set it globally. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10581 If the value is a coding system, it is used for encoding of output, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10582 when writing it to a file and when sending it to a file or subprocess. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10583 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10584 If this does not specify a coding system, an appropriate element |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10585 is used from one of the coding system alists. |
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10586 There are three such tables: `file-coding-system-alist', |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10587 `process-coding-system-alist', and `network-coding-system-alist'. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10588 For output to files, if the above procedure does not specify a coding system, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10589 the value of `buffer-file-coding-system' is used. */); |
17052 | 10590 Vcoding_system_for_write = Qnil; |
10591 | |
10592 DEFVAR_LISP ("last-coding-system-used", &Vlast_coding_system_used, | |
88365 | 10593 doc: /* |
10594 Coding system used in the latest file or process I/O. */); | |
17052 | 10595 Vlast_coding_system_used = Qnil; |
10596 | |
89686
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10597 DEFVAR_LISP ("last-code-conversion-error", &Vlast_code_conversion_error, |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10598 doc: /* |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10599 Error status of the last code conversion. |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10600 |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10601 When an error was detected in the last code conversion, this variable |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10602 is set to one of the following symbols. |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10603 `insufficient-source' |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10604 `inconsistent-eol' |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10605 `invalid-source' |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10606 `interrupted' |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10607 `insufficient-memory' |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10608 When no error was detected, the value doesn't change. So, to check |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10609 the error status of a code conversion by this variable, you must |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10610 explicitly set this variable to nil before performing code |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10611 conversion. */); |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10612 Vlast_code_conversion_error = Qnil; |
9bfefb13fe83
(Qinsufficient_source, Qinconsistent_eol)
Kenichi Handa <handa@m17n.org>
parents:
89676
diff
changeset
|
10613 |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10614 DEFVAR_BOOL ("inhibit-eol-conversion", &inhibit_eol_conversion, |
88365 | 10615 doc: /* |
10616 *Non-nil means always inhibit code conversion of end-of-line format. | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10617 See info node `Coding Systems' and info node `Text and Binary' concerning |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10618 such conversion. */); |
18650
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10619 inhibit_eol_conversion = 0; |
aa3f2820e2ac
(Qemacs_mule, inhibit_eol_conversion): New variables.
Kenichi Handa <handa@m17n.org>
parents:
18613
diff
changeset
|
10620 |
21574
30394e3ae7f8
(syms_of_coding): Declare and define inherit-process-coding-system.
Eli Zaretskii <eliz@gnu.org>
parents:
21520
diff
changeset
|
10621 DEFVAR_BOOL ("inherit-process-coding-system", &inherit_process_coding_system, |
88365 | 10622 doc: /* |
10623 Non-nil means process buffer inherits coding system of process output. | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10624 Bind it to t if the process output is to be treated as if it were a file |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10625 read from some filesystem. */); |
21574
30394e3ae7f8
(syms_of_coding): Declare and define inherit-process-coding-system.
Eli Zaretskii <eliz@gnu.org>
parents:
21520
diff
changeset
|
10626 inherit_process_coding_system = 0; |
30394e3ae7f8
(syms_of_coding): Declare and define inherit-process-coding-system.
Eli Zaretskii <eliz@gnu.org>
parents:
21520
diff
changeset
|
10627 |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10628 DEFVAR_LISP ("file-coding-system-alist", &Vfile_coding_system_alist, |
88365 | 10629 doc: /* |
10630 Alist to decide a coding system to use for a file I/O operation. | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10631 The format is ((PATTERN . VAL) ...), |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10632 where PATTERN is a regular expression matching a file name, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10633 VAL is a coding system, a cons of coding systems, or a function symbol. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10634 If VAL is a coding system, it is used for both decoding and encoding |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10635 the file contents. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10636 If VAL is a cons of coding systems, the car part is used for decoding, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10637 and the cdr part is used for encoding. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10638 If VAL is a function symbol, the function must return a coding system |
72323
af796bc81ff0
(syms_of_coding): Improve the docstring
Kenichi Handa <handa@m17n.org>
parents:
72188
diff
changeset
|
10639 or a cons of coding systems which are used as above. The function is |
af796bc81ff0
(syms_of_coding): Improve the docstring
Kenichi Handa <handa@m17n.org>
parents:
72188
diff
changeset
|
10640 called with an argument that is a list of the arguments with which |
81611
ae42ad5f89e6
(Ffind_operation_coding_system): Docstring improved.
Kenichi Handa <handa@m17n.org>
parents:
75348
diff
changeset
|
10641 `find-operation-coding-system' was called. If the function can't decide |
ae42ad5f89e6
(Ffind_operation_coding_system): Docstring improved.
Kenichi Handa <handa@m17n.org>
parents:
75348
diff
changeset
|
10642 a coding system, it can return `undecided' so that the normal |
ae42ad5f89e6
(Ffind_operation_coding_system): Docstring improved.
Kenichi Handa <handa@m17n.org>
parents:
75348
diff
changeset
|
10643 code-detection is performed. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10644 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10645 See also the function `find-operation-coding-system' |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10646 and the variable `auto-coding-alist'. */); |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10647 Vfile_coding_system_alist = Qnil; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10648 |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10649 DEFVAR_LISP ("process-coding-system-alist", &Vprocess_coding_system_alist, |
88365 | 10650 doc: /* |
10651 Alist to decide a coding system to use for a process I/O operation. | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10652 The format is ((PATTERN . VAL) ...), |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10653 where PATTERN is a regular expression matching a program name, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10654 VAL is a coding system, a cons of coding systems, or a function symbol. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10655 If VAL is a coding system, it is used for both decoding what received |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10656 from the program and encoding what sent to the program. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10657 If VAL is a cons of coding systems, the car part is used for decoding, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10658 and the cdr part is used for encoding. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10659 If VAL is a function symbol, the function must return a coding system |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10660 or a cons of coding systems which are used as above. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10661 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10662 See also the function `find-operation-coding-system'. */); |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10663 Vprocess_coding_system_alist = Qnil; |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10664 |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10665 DEFVAR_LISP ("network-coding-system-alist", &Vnetwork_coding_system_alist, |
88365 | 10666 doc: /* |
10667 Alist to decide a coding system to use for a network I/O operation. | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10668 The format is ((PATTERN . VAL) ...), |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10669 where PATTERN is a regular expression matching a network service name |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10670 or is a port number to connect to, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10671 VAL is a coding system, a cons of coding systems, or a function symbol. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10672 If VAL is a coding system, it is used for both decoding what received |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10673 from the network stream and encoding what sent to the network stream. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10674 If VAL is a cons of coding systems, the car part is used for decoding, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10675 and the cdr part is used for encoding. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10676 If VAL is a function symbol, the function must return a coding system |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10677 or a cons of coding systems which are used as above. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10678 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10679 See also the function `find-operation-coding-system'. */); |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10680 Vnetwork_coding_system_alist = Qnil; |
17052 | 10681 |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10682 DEFVAR_LISP ("locale-coding-system", &Vlocale_coding_system, |
41026
6f20449b7e12
(syms_of_coding): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
41006
diff
changeset
|
10683 doc: /* Coding system to use with system messages. |
6f20449b7e12
(syms_of_coding): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
41006
diff
changeset
|
10684 Also used for decoding keyboard input on X Window system. */); |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10685 Vlocale_coding_system = Qnil; |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10686 |
29182
1d1c27067af4
(encode_eol): Add null statement after label.
Dave Love <fx@gnu.org>
parents:
29172
diff
changeset
|
10687 /* The eol mnemonics are reset in startup.el system-dependently. */ |
24200
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10688 DEFVAR_LISP ("eol-mnemonic-unix", &eol_mnemonic_unix, |
88365 | 10689 doc: /* |
10690 *String displayed in mode line for UNIX-like (LF) end-of-line format. */); | |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10691 eol_mnemonic_unix = make_pure_c_string (":"); |
24200
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10692 |
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10693 DEFVAR_LISP ("eol-mnemonic-dos", &eol_mnemonic_dos, |
88365 | 10694 doc: /* |
10695 *String displayed in mode line for DOS-like (CRLF) end-of-line format. */); | |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10696 eol_mnemonic_dos = make_pure_c_string ("\\"); |
24200
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10697 |
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10698 DEFVAR_LISP ("eol-mnemonic-mac", &eol_mnemonic_mac, |
88365 | 10699 doc: /* |
10700 *String displayed in mode line for MAC-like (CR) end-of-line format. */); | |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10701 eol_mnemonic_mac = make_pure_c_string ("/"); |
24200
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10702 |
b9d9fccad516
(syms_of_coding): eol-mnemonic-* variables are now
Eli Zaretskii <eliz@gnu.org>
parents:
24178
diff
changeset
|
10703 DEFVAR_LISP ("eol-mnemonic-undecided", &eol_mnemonic_undecided, |
88365 | 10704 doc: /* |
10705 *String displayed in mode line when end-of-line format is not yet determined. */); | |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10706 eol_mnemonic_undecided = make_pure_c_string (":"); |
17052 | 10707 |
22119
592bb8b9bcfd
Change terms unify/unification to
Kenichi Handa <handa@m17n.org>
parents:
22020
diff
changeset
|
10708 DEFVAR_LISP ("enable-character-translation", &Venable_character_translation, |
88365 | 10709 doc: /* |
10710 *Non-nil enables character translation while encoding and decoding. */); | |
22119
592bb8b9bcfd
Change terms unify/unification to
Kenichi Handa <handa@m17n.org>
parents:
22020
diff
changeset
|
10711 Venable_character_translation = Qt; |
592bb8b9bcfd
Change terms unify/unification to
Kenichi Handa <handa@m17n.org>
parents:
22020
diff
changeset
|
10712 |
22186
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
10713 DEFVAR_LISP ("standard-translation-table-for-decode", |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10714 &Vstandard_translation_table_for_decode, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10715 doc: /* Table for translating characters while decoding. */); |
22186
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
10716 Vstandard_translation_table_for_decode = Qnil; |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
10717 |
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
10718 DEFVAR_LISP ("standard-translation-table-for-encode", |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10719 &Vstandard_translation_table_for_encode, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10720 doc: /* Table for translating characters while encoding. */); |
22186
fc4aaf1b1772
Change term "character translation table" to "translation table".
Kenichi Handa <handa@m17n.org>
parents:
22166
diff
changeset
|
10721 Vstandard_translation_table_for_encode = Qnil; |
17052 | 10722 |
88365 | 10723 DEFVAR_LISP ("charset-revision-table", &Vcharset_revision_table, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10724 doc: /* Alist of charsets vs revision numbers. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10725 While encoding, if a charset (car part of an element) is found, |
88365 | 10726 designate it with the escape sequence identifying revision (cdr part |
10727 of the element). */); | |
10728 Vcharset_revision_table = Qnil; | |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10729 |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10730 DEFVAR_LISP ("default-process-coding-system", |
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10731 &Vdefault_process_coding_system, |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10732 doc: /* Cons of coding systems used for process I/O by default. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10733 The car part is used for decoding a process output, |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10734 the cdr part is used for encoding a text to be sent to a process. */); |
18180
5f4c4da24e75
(Vcoding_system_alist): Deleted.
Kenichi Handa <handa@m17n.org>
parents:
18002
diff
changeset
|
10735 Vdefault_process_coding_system = Qnil; |
19280
e755044718ee
(ENCODE_ISO_CHARACTER_DIMENSION1): Pay attention to
Kenichi Handa <handa@m17n.org>
parents:
19193
diff
changeset
|
10736 |
19365
d9374f5ebd3a
(CODING_FLAG_ISO_LATIN_EXTRA): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19285
diff
changeset
|
10737 DEFVAR_LISP ("latin-extra-code-table", &Vlatin_extra_code_table, |
88365 | 10738 doc: /* |
10739 Table of extra Latin codes in the range 128..159 (inclusive). | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10740 This is a vector of length 256. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10741 If Nth element is non-nil, the existence of code N in a file |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10742 \(or output of subprocess) doesn't prevent it to be detected as |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10743 a coding system of ISO 2022 variant which has a flag |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10744 `accept-latin-extra-code' t (e.g. iso-latin-1) on reading a file |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10745 or reading output of a subprocess. |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10746 Only 128th through 159th elements have a meaning. */); |
19365
d9374f5ebd3a
(CODING_FLAG_ISO_LATIN_EXTRA): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19285
diff
changeset
|
10747 Vlatin_extra_code_table = Fmake_vector (make_number (256), Qnil); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10748 |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10749 DEFVAR_LISP ("select-safe-coding-system-function", |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10750 &Vselect_safe_coding_system_function, |
88365 | 10751 doc: /* |
10752 Function to call to select safe coding system for encoding a text. | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10753 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10754 If set, this function is called to force a user to select a proper |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10755 coding system which can encode the text in the case that a default |
87778
0ec6f8d26078
(select-safe-coding-system-function): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
87710
diff
changeset
|
10756 coding system used in each operation can't encode the text. The |
0ec6f8d26078
(select-safe-coding-system-function): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
87710
diff
changeset
|
10757 function should take care that the buffer is not modified while |
0ec6f8d26078
(select-safe-coding-system-function): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
87710
diff
changeset
|
10758 the coding system is being selected. |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10759 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10760 The default value is `select-safe-coding-system' (which see). */); |
20718
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10761 Vselect_safe_coding_system_function = Qnil; |
c600dea3b06b
Vselect_safe_coding_system_function): New variable.
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
10762 |
48874
3002a87cc629
(coding_system_require_warning): New variable.
Kenichi Handa <handa@m17n.org>
parents:
48829
diff
changeset
|
10763 DEFVAR_BOOL ("coding-system-require-warning", |
3002a87cc629
(coding_system_require_warning): New variable.
Kenichi Handa <handa@m17n.org>
parents:
48829
diff
changeset
|
10764 &coding_system_require_warning, |
3002a87cc629
(coding_system_require_warning): New variable.
Kenichi Handa <handa@m17n.org>
parents:
48829
diff
changeset
|
10765 doc: /* Internal use only. |
49539
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10766 If non-nil, on writing a file, `select-safe-coding-system-function' is |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10767 called even if `coding-system-for-write' is non-nil. The command |
1ad5bfbb831a
(syms_of_coding): Add `...' for symbols in the docstring of
Kenichi Handa <handa@m17n.org>
parents:
48874
diff
changeset
|
10768 `universal-coding-system-argument' binds this variable to t temporarily. */); |
48874
3002a87cc629
(coding_system_require_warning): New variable.
Kenichi Handa <handa@m17n.org>
parents:
48829
diff
changeset
|
10769 coding_system_require_warning = 0; |
3002a87cc629
(coding_system_require_warning): New variable.
Kenichi Handa <handa@m17n.org>
parents:
48829
diff
changeset
|
10770 |
3002a87cc629
(coding_system_require_warning): New variable.
Kenichi Handa <handa@m17n.org>
parents:
48829
diff
changeset
|
10771 |
30292
14a9937df1f5
(syms_of_coding): Fix typo in spelling of variable
Gerd Moellmann <gerd@gnu.org>
parents:
30263
diff
changeset
|
10772 DEFVAR_BOOL ("inhibit-iso-escape-detection", |
30204
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
10773 &inhibit_iso_escape_detection, |
88365 | 10774 doc: /* |
101040 | 10775 If non-nil, Emacs ignores ISO-2022 escape sequences during code detection. |
10776 | |
10777 When Emacs reads text, it tries to detect how the text is encoded. | |
10778 This code detection is sensitive to escape sequences. If Emacs sees | |
10779 a valid ISO-2022 escape sequence, it assumes the text is encoded in one | |
10780 of the ISO2022 encodings, and decodes text by the corresponding coding | |
10781 system (e.g. `iso-2022-7bit'). | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10782 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10783 However, there may be a case that you want to read escape sequences in |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10784 a file as is. In such a case, you can set this variable to non-nil. |
101040 | 10785 Then the code detection will ignore any escape sequences, and no text is |
10786 detected as encoded in some ISO-2022 encoding. The result is that all | |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10787 escape sequences become visible in a buffer. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10788 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10789 The default value is nil, and it is strongly recommended not to change |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10790 it. That is because many Emacs Lisp source files that contain |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10791 non-ASCII characters are encoded by the coding system `iso-2022-7bit' |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10792 in Emacs's distribution, and they won't be decoded correctly on |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10793 reading if you suppress escape sequence detection. |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10794 |
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10795 The other way to read escape sequences in a file without decoding is |
101040 | 10796 to explicitly specify some coding system that doesn't use ISO-2022 |
40713
42351475da08
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
40656
diff
changeset
|
10797 escape sequence (e.g `latin-1') on reading by \\[universal-coding-system-argument]. */); |
30204
35aec8514228
(inhibit_iso_escape_detection): New variable.
Kenichi Handa <handa@m17n.org>
parents:
29985
diff
changeset
|
10798 inhibit_iso_escape_detection = 0; |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
10799 |
101040 | 10800 DEFVAR_BOOL ("inhibit-null-byte-detection", |
10801 &inhibit_null_byte_detection, | |
10802 doc: /* If non-nil, Emacs ignores null bytes on code detection. | |
10803 By default, Emacs treats it as binary data, and does not attempt to | |
10804 decode it. The effect is as if you specified `no-conversion' for | |
10805 reading that text. | |
10806 | |
10807 Set this to non-nil when a regular text happens to include null bytes. | |
10808 Examples are Index nodes of Info files and null-byte delimited output | |
10809 from GNU Find and GNU Grep. Emacs will then ignore the null bytes and | |
10810 decode text as usual. */); | |
10811 inhibit_null_byte_detection = 0; | |
10812 | |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
10813 DEFVAR_LISP ("translation-table-for-input", &Vtranslation_table_for_input, |
48230
c2ce8280fb97
(Vtranslation_table_for_input): New.
Dave Love <fx@gnu.org>
parents:
48182
diff
changeset
|
10814 doc: /* Char table for translating self-inserting characters. |
95356
90b4a0dc21cc
(Fdecode_coding_region, Fencode_coding_region, Fencode_coding_string):
Juanma Barranquero <lekktu@gmail.com>
parents:
95353
diff
changeset
|
10815 This is applied to the result of input methods, not their input. |
101854
7e576fc18303
(syms_of_coding) <translation-table-for-input>: Modify doc string to
Eli Zaretskii <eliz@gnu.org>
parents:
101776
diff
changeset
|
10816 See also `keyboard-translate-table'. |
7e576fc18303
(syms_of_coding) <translation-table-for-input>: Modify doc string to
Eli Zaretskii <eliz@gnu.org>
parents:
101776
diff
changeset
|
10817 |
7e576fc18303
(syms_of_coding) <translation-table-for-input>: Modify doc string to
Eli Zaretskii <eliz@gnu.org>
parents:
101776
diff
changeset
|
10818 Use of this variable for character code unification was rendered |
7e576fc18303
(syms_of_coding) <translation-table-for-input>: Modify doc string to
Eli Zaretskii <eliz@gnu.org>
parents:
101776
diff
changeset
|
10819 obsolete in Emacs 23.1 and later, since Unicode is now the basis of |
7e576fc18303
(syms_of_coding) <translation-table-for-input>: Modify doc string to
Eli Zaretskii <eliz@gnu.org>
parents:
101776
diff
changeset
|
10820 internal character representation. */); |
48182
9474e269efd1
Reformat some DEFUNs so that etags works.
Dave Love <fx@gnu.org>
parents:
48125
diff
changeset
|
10821 Vtranslation_table_for_input = Qnil; |
89483 | 10822 |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10823 { |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10824 Lisp_Object args[coding_arg_max]; |
89483 | 10825 Lisp_Object plist[16]; |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10826 int i; |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10827 |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10828 for (i = 0; i < coding_arg_max; i++) |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10829 args[i] = Qnil; |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10830 |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10831 plist[0] = intern_c_string (":name"); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10832 plist[1] = args[coding_arg_name] = Qno_conversion; |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10833 plist[2] = intern_c_string (":mnemonic"); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10834 plist[3] = args[coding_arg_mnemonic] = make_number ('='); |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10835 plist[4] = intern_c_string (":coding-type"); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10836 plist[5] = args[coding_arg_coding_type] = Qraw_text; |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10837 plist[6] = intern_c_string (":ascii-compatible-p"); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10838 plist[7] = args[coding_arg_ascii_compatible_p] = Qt; |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10839 plist[8] = intern_c_string (":default-char"); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10840 plist[9] = args[coding_arg_default_char] = make_number (0); |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10841 plist[10] = intern_c_string (":for-unibyte"); |
89483 | 10842 plist[11] = args[coding_arg_for_unibyte] = Qt; |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10843 plist[12] = intern_c_string (":docstring"); |
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10844 plist[13] = make_pure_c_string ("Do no conversion.\n\ |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10845 \n\ |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10846 When you visit a file with this coding, the file is read into a\n\ |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10847 unibyte buffer as is, thus each byte of a file is treated as a\n\ |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10848 character."); |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10849 plist[14] = intern_c_string (":eol-type"); |
89483 | 10850 plist[15] = args[coding_arg_eol_type] = Qunix; |
10851 args[coding_arg_plist] = Flist (16, plist); | |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10852 Fdefine_coding_system_internal (coding_arg_max, args); |
90011
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10853 |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10854 plist[1] = args[coding_arg_name] = Qundecided; |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10855 plist[3] = args[coding_arg_mnemonic] = make_number ('-'); |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10856 plist[5] = args[coding_arg_coding_type] = Qundecided; |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10857 /* This is already set. |
90214
460ee00505d5
(QCascii_compatible_p): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90201
diff
changeset
|
10858 plist[7] = args[coding_arg_ascii_compatible_p] = Qt; */ |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10859 plist[8] = intern_c_string (":charset-list"); |
90011
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10860 plist[9] = args[coding_arg_charset_list] = Fcons (Qascii, Qnil); |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10861 plist[11] = args[coding_arg_for_unibyte] = Qnil; |
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
10862 plist[13] = make_pure_c_string ("No conversion on encoding, automatic conversion on decoding."); |
90011
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10863 plist[15] = args[coding_arg_eol_type] = Qnil; |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10864 args[coding_arg_plist] = Flist (16, plist); |
26cef35a1562
(setup_coding_system): If coding_system is nil, use
Kenichi Handa <handa@m17n.org>
parents:
89976
diff
changeset
|
10865 Fdefine_coding_system_internal (coding_arg_max, args); |
88456
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10866 } |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10867 |
a7b309f72920
(coding_alloc_by_making_gap): Check the case that the
Kenichi Handa <handa@m17n.org>
parents:
88443
diff
changeset
|
10868 setup_coding_system (Qno_conversion, &safe_terminal_coding); |
89467
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10869 |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10870 { |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10871 int i; |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10872 |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10873 for (i = 0; i < coding_category_max; i++) |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10874 Fset (AREF (Vcoding_category_table, i), Qno_conversion); |
e911ca706166
(Fset_coding_system_priority): Doc fix. Update values
Kenichi Handa <handa@m17n.org>
parents:
89462
diff
changeset
|
10875 } |
109158
6175ebc3b6ce
* coding.c: Use SPECPDL_INDEX, DOS_NT.
Juanma Barranquero <lekktu@gmail.com>
parents:
109126
diff
changeset
|
10876 #if defined (DOS_NT) |
90394
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
10877 system_eol_type = Qdos; |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
10878 #else |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
10879 system_eol_type = Qunix; |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
10880 #endif |
263867fe7b55
(system_eol_type): Sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90380
diff
changeset
|
10881 staticpro (&system_eol_type); |
17052 | 10882 } |
10883 | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10884 char * |
109126
aec1143e8d85
Convert (most) functions in src to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109100
diff
changeset
|
10885 emacs_strerror (int error_number) |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10886 { |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10887 char *str; |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10888 |
26526
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26240
diff
changeset
|
10889 synchronize_system_messages_locale (); |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10890 str = strerror (error_number); |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10891 |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10892 if (! NILP (Vlocale_coding_system)) |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10893 { |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10894 Lisp_Object dec = code_convert_string_norecord (build_string (str), |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10895 Vlocale_coding_system, |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10896 0); |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46293
diff
changeset
|
10897 str = (char *) SDATA (dec); |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10898 } |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10899 |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10900 return str; |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10901 } |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26067
diff
changeset
|
10902 |
17052 | 10903 #endif /* emacs */ |
29184 | 10904 |
52401 | 10905 /* arch-tag: 3a3a2b01-5ff6-4071-9afe-f5b808d9229d |
10906 (do not change this comment) */ |