Mercurial > emacs
annotate lisp/international/characters.el @ 29453:22f8105a7dc7
Remove eval-when-compile.
(cyrillic-koi8-r-nonascii-translation-table): Define it as a
translation table made from cyrillic-koi8-r-decode-table.
(cyrillic-koi8-r-encode-table): Define it as a translation table
made from the reverse map of above.
(ccl-decode-koi8): Use translate-character.
(ccl-encode-koi8, ccl-encode-koi8-font): Likewize
(cyrillic-alternativnyj-nonascii-translation-table): Define it as
a translation table made from cyrillic-alternativnyj-decode-table.
(cyrillic-alternativnyj-encode-table): Define it as a translation
table made from the reverse map of above.
(ccl-decode-alternativnyj): Use translate-character.
(ccl-encode-alternativnyj, ccl-encode-alternativnyj-font):
Likewize
author | Kenichi Handa <handa@m17n.org> |
---|---|
date | Tue, 06 Jun 2000 02:10:04 +0000 |
parents | 038c13f83357 |
children | b41bc1b0a044 |
rev | line source |
---|---|
17052 | 1 ;;; characters.el --- set syntax and category for multibyte characters |
2 | |
19958
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
3 ;; Copyright (C) 1995, 1997 Electrotechnical Laboratory, JAPAN. |
18377
8b4a66c66dd6
Change copyright notice.
Richard M. Stallman <rms@gnu.org>
parents:
18304
diff
changeset
|
4 ;; Licensed to the Free Software Foundation. |
17052 | 5 |
6 ;; Keywords: multibyte character, character set, syntax, category | |
7 | |
8 ;; This file is part of GNU Emacs. | |
9 | |
10 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
11 ;; it under the terms of the GNU General Public License as published by | |
12 ;; the Free Software Foundation; either version 2, or (at your option) | |
13 ;; any later version. | |
14 | |
15 ;; GNU Emacs is distributed in the hope that it will be useful, | |
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
18 ;; GNU General Public License for more details. | |
19 | |
20 ;; You should have received a copy of the GNU General Public License | |
17071 | 21 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
23 ;; Boston, MA 02111-1307, USA. | |
17052 | 24 |
25 ;;; Commentary: | |
26 | |
27 ;; This file contains multibyte characters. Save this file always in | |
18197
90235db802c7
Comment changed (iso-2022-7 -> iso-2022-7bit).
Kenichi Handa <handa@m17n.org>
parents:
17753
diff
changeset
|
28 ;; the coding system `iso-2022-7bit'. |
17052 | 29 |
18205
40dc3b2e9e27
Delete syntax stuff for Latin-1 and Latin-2.
Richard M. Stallman <rms@gnu.org>
parents:
18197
diff
changeset
|
30 ;; This file does not define the syntax for Latin-N character sets; |
40dc3b2e9e27
Delete syntax stuff for Latin-1 and Latin-2.
Richard M. Stallman <rms@gnu.org>
parents:
18197
diff
changeset
|
31 ;; those are defined by the files latin-N.el. |
40dc3b2e9e27
Delete syntax stuff for Latin-1 and Latin-2.
Richard M. Stallman <rms@gnu.org>
parents:
18197
diff
changeset
|
32 |
17052 | 33 ;;; Predefined categories. |
34 | |
35 ;; For each character set. | |
36 | |
37 (define-category ?a "ASCII") | |
38 (define-category ?l "Latin") | |
39 (define-category ?t "Thai") | |
40 (define-category ?g "Greek") | |
41 (define-category ?b "Arabic") | |
42 (define-category ?w "Hebrew") | |
43 (define-category ?y "Cyrillic") | |
44 (define-category ?k "Japanese katakana") | |
45 (define-category ?r "Japanese roman") | |
46 (define-category ?c "Chinese") | |
47 (define-category ?j "Japanese") | |
48 (define-category ?h "Korean") | |
49 (define-category ?e "Ethiopic (Ge'ez)") | |
50 (define-category ?v "Vietnamese") | |
51 (define-category ?i "Indian") | |
17078
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
52 (define-category ?o "Lao") |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
53 (define-category ?q "Tibetan") |
17052 | 54 |
55 ;; For each group (row) of 2-byte character sets. | |
56 | |
22529 | 57 (define-category ?A "Alpha-numeric characters of 2-byte character sets") |
17052 | 58 (define-category ?C "Chinese (Han) characters of 2-byte character sets") |
22529 | 59 (define-category ?G "Greek characters of 2-byte character sets") |
17052 | 60 (define-category ?H "Japanese Hiragana characters of 2-byte character sets") |
61 (define-category ?K "Japanese Katakana characters of 2-byte character sets") | |
62 (define-category ?N "Korean Hangul characters of 2-byte character sets") | |
22529 | 63 (define-category ?Y "Cyrillic characters of 2-byte character sets") |
17052 | 64 (define-category ?I "Indian Glyphs") |
65 | |
66 ;; For phonetic classifications. | |
67 | |
68 (define-category ?0 "consonant") | |
18561
f3c28fd5118e
Modify docstring of char category
Kenichi Handa <handa@m17n.org>
parents:
18377
diff
changeset
|
69 (define-category ?1 "base (independent) vowel") |
17052 | 70 (define-category ?2 "upper diacritical mark (including upper vowel)") |
71 (define-category ?3 "lower diacritical mark (including lower vowel)") | |
72 (define-category ?4 "tone mark") | |
18561
f3c28fd5118e
Modify docstring of char category
Kenichi Handa <handa@m17n.org>
parents:
18377
diff
changeset
|
73 (define-category ?5 "symbol") |
17052 | 74 (define-category ?6 "digit") |
75 (define-category ?7 "vowel-modifying diacritical mark") | |
17078
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
76 (define-category ?8 "vowel-signs") |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
77 (define-category ?9 "semivowel lower") |
17052 | 78 |
79 ;; For filling. | |
80 (define-category ?| "While filling, we can break a line at this character.") | |
81 | |
20247 | 82 ;; For indentation calculation. |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
83 (define-category ? |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
84 "This character counts as a space for indentation purposes.") |
20247 | 85 |
22529 | 86 ;; Keep the following for `kinsoku' processing. See comments in |
17052 | 87 ;; kinsoku.el. |
88 (define-category ?> "A character which can't be placed at beginning of line.") | |
89 (define-category ?< "A character which can't be placed at end of line.") | |
90 | |
91 | |
92 ;;; Setting syntax and category. | |
93 | |
94 ;; ASCII | |
95 | |
96 (let ((ch 32)) | |
97 (while (< ch 127) ; All ASCII characters have | |
98 (modify-category-entry ch ?a) ; the category `a' (ASCII) | |
99 (modify-category-entry ch ?l) ; and `l' (Latin). | |
100 (setq ch (1+ ch)))) | |
101 | |
102 ;; Arabic character set | |
103 | |
104 (let ((charsets '(arabic-iso8859-6 | |
105 arabic-digit | |
106 arabic-1-column | |
107 arabic-2-column))) | |
108 (while charsets | |
109 (modify-syntax-entry (make-char (car charsets)) "w") | |
110 (modify-category-entry (make-char (car charsets)) ?b) | |
111 (setq charsets (cdr charsets)))) | |
112 | |
113 ;; Chinese character set (GB2312) | |
114 | |
115 (modify-syntax-entry (make-char 'chinese-gb2312) "w") | |
116 (modify-syntax-entry (make-char 'chinese-gb2312 33) "_") | |
117 (modify-syntax-entry (make-char 'chinese-gb2312 34) "_") | |
118 (modify-syntax-entry (make-char 'chinese-gb2312 41) "_") | |
119 (modify-syntax-entry ?\$A!2(B "($A!3(B") | |
120 (modify-syntax-entry ?\$A!4(B "($A!5(B") | |
121 (modify-syntax-entry ?\$A!6(B "($A!7(B") | |
122 (modify-syntax-entry ?\$A!8(B "($A!9(B") | |
123 (modify-syntax-entry ?\$A!:(B "($A!;(B") | |
124 (modify-syntax-entry ?\$A!<(B "($A!=(B") | |
125 (modify-syntax-entry ?\$A!>(B "($A!?(B") | |
126 (modify-syntax-entry ?\$A!3(B ")$A!2(B") | |
127 (modify-syntax-entry ?\$A!5(B ")$A!4(B") | |
128 (modify-syntax-entry ?\$A!7(B ")$A!6(B") | |
129 (modify-syntax-entry ?\$A!9(B ")$A!8(B") | |
130 (modify-syntax-entry ?\$A!;(B ")$A!:(B") | |
131 (modify-syntax-entry ?\$A!=(B ")$A!<(B") | |
132 (modify-syntax-entry ?\$A!?(B ")$A!>(B") | |
133 | |
134 (modify-category-entry (make-char 'chinese-gb2312) ?c) | |
135 (modify-category-entry (make-char 'chinese-gb2312) ?\|) | |
136 (modify-category-entry (make-char 'chinese-gb2312 35) ?A) | |
137 (modify-category-entry (make-char 'chinese-gb2312 36) ?H) | |
138 (modify-category-entry (make-char 'chinese-gb2312 37) ?K) | |
139 (modify-category-entry (make-char 'chinese-gb2312 38) ?G) | |
140 (modify-category-entry (make-char 'chinese-gb2312 39) ?Y) | |
141 (let ((row 48)) | |
142 (while (< row 127) | |
143 (modify-category-entry (make-char 'chinese-gb2312 row) ?C) | |
144 (setq row (1+ row)))) | |
145 | |
146 ;; Chinese character set (BIG5) | |
147 | |
148 (let ((generic-big5-1-char (make-char 'chinese-big5-1)) | |
149 (generic-big5-2-char (make-char 'chinese-big5-2))) | |
150 (modify-syntax-entry generic-big5-1-char "w") | |
151 (modify-syntax-entry generic-big5-2-char "w") | |
152 | |
153 (modify-category-entry generic-big5-1-char ?c) | |
154 (modify-category-entry generic-big5-2-char ?c) | |
155 | |
156 (modify-category-entry generic-big5-1-char ?C) | |
157 (modify-category-entry generic-big5-2-char ?C) | |
158 | |
159 (modify-category-entry generic-big5-1-char ?\|) | |
160 (modify-category-entry generic-big5-2-char ?\|)) | |
161 | |
162 | |
163 ;; Chinese character set (CNS11643) | |
164 | |
165 (let ((cns-list '(chinese-cns11643-1 | |
166 chinese-cns11643-2 | |
167 chinese-cns11643-3 | |
168 chinese-cns11643-4 | |
169 chinese-cns11643-5 | |
170 chinese-cns11643-6 | |
171 chinese-cns11643-7)) | |
172 generic-char) | |
173 (while cns-list | |
174 (setq generic-char (make-char (car cns-list))) | |
175 (modify-syntax-entry generic-char "w") | |
176 (modify-category-entry generic-char ?c) | |
177 (modify-category-entry generic-char ?C) | |
178 (modify-category-entry generic-char ?|) | |
179 (setq cns-list (cdr cns-list)))) | |
180 | |
181 ;; Cyrillic character set (ISO-8859-5) | |
182 | |
183 (modify-category-entry (make-char 'cyrillic-iso8859-5) ?y) | |
184 | |
19958
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
185 (modify-syntax-entry (make-char 'cyrillic-iso8859-5 160) " ") |
17052 | 186 (modify-syntax-entry ?,L-(B ".") |
187 (modify-syntax-entry ?,Lp(B ".") | |
188 (modify-syntax-entry ?,L}(B ".") | |
19958
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
189 (let ((tbl (standard-case-table))) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
190 (set-case-syntax-pair ?,L!(B ?,Lq(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
191 (set-case-syntax-pair ?,L"(B ?,Lr(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
192 (set-case-syntax-pair ?,L#(B ?,Ls(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
193 (set-case-syntax-pair ?,L$(B ?,Lt(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
194 (set-case-syntax-pair ?,L%(B ?,Lu(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
195 (set-case-syntax-pair ?,L&(B ?,Lv(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
196 (set-case-syntax-pair ?,L'(B ?,Lw(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
197 (set-case-syntax-pair ?,L((B ?,Lx(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
198 (set-case-syntax-pair ?,L)(B ?,Ly(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
199 (set-case-syntax-pair ?,L*(B ?,Lz(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
200 (set-case-syntax-pair ?,L+(B ?,L{(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
201 (set-case-syntax-pair ?,L,(B ?,L|(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
202 (set-case-syntax-pair ?,L.(B ?,L~(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
203 (set-case-syntax-pair ?,L/(B ?,L(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
204 (set-case-syntax-pair ?,L0(B ?,LP(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
205 (set-case-syntax-pair ?,L1(B ?,LQ(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
206 (set-case-syntax-pair ?,L2(B ?,LR(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
207 (set-case-syntax-pair ?,L3(B ?,LS(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
208 (set-case-syntax-pair ?,L4(B ?,LT(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
209 (set-case-syntax-pair ?,L5(B ?,LU(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
210 (set-case-syntax-pair ?,L6(B ?,LV(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
211 (set-case-syntax-pair ?,L7(B ?,LW(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
212 (set-case-syntax-pair ?,L8(B ?,LX(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
213 (set-case-syntax-pair ?,L9(B ?,LY(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
214 (set-case-syntax-pair ?,L:(B ?,LZ(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
215 (set-case-syntax-pair ?,L;(B ?,L[(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
216 (set-case-syntax-pair ?,L<(B ?,L\(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
217 (set-case-syntax-pair ?,L=(B ?,L](B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
218 (set-case-syntax-pair ?,L>(B ?,L^(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
219 (set-case-syntax-pair ?,L?(B ?,L_(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
220 (set-case-syntax-pair ?,L@(B ?,L`(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
221 (set-case-syntax-pair ?,LA(B ?,La(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
222 (set-case-syntax-pair ?,LB(B ?,Lb(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
223 (set-case-syntax-pair ?,LC(B ?,Lc(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
224 (set-case-syntax-pair ?,LD(B ?,Ld(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
225 (set-case-syntax-pair ?,LE(B ?,Le(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
226 (set-case-syntax-pair ?,LF(B ?,Lf(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
227 (set-case-syntax-pair ?,LG(B ?,Lg(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
228 (set-case-syntax-pair ?,LH(B ?,Lh(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
229 (set-case-syntax-pair ?,LI(B ?,Li(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
230 (set-case-syntax-pair ?,LJ(B ?,Lj(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
231 (set-case-syntax-pair ?,LK(B ?,Lk(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
232 (set-case-syntax-pair ?,LL(B ?,Ll(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
233 (set-case-syntax-pair ?,LM(B ?,Lm(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
234 (set-case-syntax-pair ?,LN(B ?,Ln(B tbl) |
f7ab34ae92bb
Set case-table for Cyrillic characters.
Richard M. Stallman <rms@gnu.org>
parents:
18561
diff
changeset
|
235 (set-case-syntax-pair ?,LO(B ?,Lo(B tbl)) |
17052 | 236 |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
237 ;; Devanagari character set |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
238 |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
239 (let ((deflist '(;; chars syntax category |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
240 ("$(5!!!"!#(B" "w" ?7) ; vowel-modifying diacritical mark |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
241 ; chandrabindu, anuswar, visarga |
18561
f3c28fd5118e
Modify docstring of char category
Kenichi Handa <handa@m17n.org>
parents:
18377
diff
changeset
|
242 ("$(5!$(B-$(5!2(B" "w" ?1) ; independent vowel |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
243 ("$(5!3(B-$(5!X(B" "w" ?0) ; consonant |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
244 ("$(5!Z(B-$(5!g(B" "w" ?8) ; matra |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
245 ("$(5!q(B-$(5!z(B" "w" ?6) ; digit |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
246 )) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
247 elm chars len syntax category to ch i) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
248 (while deflist |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
249 (setq elm (car deflist)) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
250 (setq chars (car elm) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
251 len (length chars) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
252 syntax (nth 1 elm) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
253 category (nth 2 elm) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
254 i 0) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
255 (while (< i len) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
256 (if (= (aref chars i) ?-) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
257 (setq i (1+ i) |
20843 | 258 to (aref chars i)) |
259 (setq ch (aref chars i) | |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
260 to ch)) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
261 (while (<= ch to) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
262 (modify-syntax-entry ch syntax) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
263 (modify-category-entry ch category) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
264 (setq ch (1+ ch))) |
20843 | 265 (setq i (1+ i))) |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
266 (setq deflist (cdr deflist)))) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
267 |
17052 | 268 ;; Ethiopic character set |
269 | |
270 (modify-category-entry (make-char 'ethiopic) ?e) | |
18304
58b39b4108d5
Set syntaxes of Ethiopic characters.
Kenichi Handa <handa@m17n.org>
parents:
18205
diff
changeset
|
271 (modify-syntax-entry (make-char 'ethiopic) "w") |
58b39b4108d5
Set syntaxes of Ethiopic characters.
Kenichi Handa <handa@m17n.org>
parents:
18205
diff
changeset
|
272 (let ((chars '(?$(3$h(B ?$(3$i(B ?$(3$j(B ?$(3$k(B ?$(3$l(B ?$(3$m(B ?$(3$n(B ?$(3$o(B ?$(3%i(B ?$(3%t(B ?$(3%u(B ?$(3%v(B ?$(3%w(B ?$(3%x(B))) |
58b39b4108d5
Set syntaxes of Ethiopic characters.
Kenichi Handa <handa@m17n.org>
parents:
18205
diff
changeset
|
273 (while chars |
58b39b4108d5
Set syntaxes of Ethiopic characters.
Kenichi Handa <handa@m17n.org>
parents:
18205
diff
changeset
|
274 (modify-syntax-entry (car chars) ".") |
58b39b4108d5
Set syntaxes of Ethiopic characters.
Kenichi Handa <handa@m17n.org>
parents:
18205
diff
changeset
|
275 (setq chars (cdr chars)))) |
17052 | 276 |
277 ;; European character set (Latin-1,2,3,4,5) | |
278 | |
279 (modify-category-entry (make-char 'latin-iso8859-1) ?l) | |
280 (modify-category-entry (make-char 'latin-iso8859-2) ?l) | |
281 (modify-category-entry (make-char 'latin-iso8859-3) ?l) | |
282 (modify-category-entry (make-char 'latin-iso8859-4) ?l) | |
283 (modify-category-entry (make-char 'latin-iso8859-9) ?l) | |
26013 | 284 (modify-category-entry (make-char 'latin-iso8859-14) ?l) |
285 (modify-category-entry (make-char 'latin-iso8859-15) ?l) | |
17052 | 286 |
20247 | 287 (modify-category-entry (make-char 'latin-iso8859-1 160) ?\ ) |
288 (modify-category-entry (make-char 'latin-iso8859-2 160) ?\ ) | |
289 (modify-category-entry (make-char 'latin-iso8859-3 160) ?\ ) | |
290 (modify-category-entry (make-char 'latin-iso8859-4 160) ?\ ) | |
291 (modify-category-entry (make-char 'latin-iso8859-9 160) ?\ ) | |
26013 | 292 (modify-category-entry (make-char 'latin-iso8859-14 160) ?\ ) |
293 (modify-category-entry (make-char 'latin-iso8859-15 160) ?\ ) | |
20247 | 294 |
17052 | 295 ;; Greek character set (ISO-8859-7) |
296 | |
297 (modify-category-entry (make-char 'greek-iso8859-7) ?g) | |
298 | |
299 (let ((c 182)) | |
300 (while (< c 255) | |
301 (modify-syntax-entry (make-char 'greek-iso8859-7 c) "w") | |
302 (setq c (1+ c)))) | |
303 (modify-syntax-entry (make-char 'greek-iso8859-7 160) "w") ; NBSP | |
304 (modify-syntax-entry ?,F7(B ".") | |
305 (modify-syntax-entry ?,F;(B ".") | |
306 (modify-syntax-entry ?,F=(B ".") | |
307 | |
308 ;; Hebrew character set (ISO-8859-8) | |
309 | |
310 (modify-category-entry (make-char 'hebrew-iso8859-8) ?w) | |
311 | |
312 (let ((c 224)) | |
313 (while (< c 251) | |
314 (modify-syntax-entry (make-char 'hebrew-iso8859-8 c) "w") | |
315 (setq c (1+ c)))) | |
316 (modify-syntax-entry (make-char 'hebrew-iso8859-8 160) "w") ; NBSP | |
317 | |
318 ;; Indian character set (IS 13194 and other Emacs original Indian charsets) | |
319 | |
320 (modify-category-entry (make-char 'indian-is13194) ?i) | |
321 (modify-category-entry (make-char 'indian-2-column) ?I) | |
322 (modify-category-entry (make-char 'indian-1-column) ?I) | |
323 | |
20843 | 324 (let ((deflist |
325 '(;; chars syntax category | |
326 ("(5!"#(B" "w" ?7) ; vowel-modifying diacritical mark | |
327 ; chandrabindu, anuswar, visarga | |
328 ("(5$(B-(52(B" "w" ?1) ; base (independent) vowel | |
329 ("(53(B-(5X(B" "w" ?0) ; consonant | |
330 ("(5Z(B-(5g(B" "w" ?8) ; matra | |
331 ("(5q(B-(5z(B" "w" ?6) ; digit | |
332 )) | |
333 elm chars len syntax category to ch i) | |
334 (while deflist | |
335 (setq elm (car deflist)) | |
336 (setq chars (car elm) | |
337 len (length chars) | |
338 syntax (nth 1 elm) | |
339 category (nth 2 elm) | |
340 i 0) | |
341 (while (< i len) | |
342 (if (= (aref chars i) ?-) | |
343 (setq i (1+ i) | |
344 to (aref chars i)) | |
345 (setq ch (aref chars i) | |
346 to ch)) | |
347 (while (<= ch to) | |
348 (modify-syntax-entry ch syntax) | |
349 (modify-category-entry ch category) | |
350 (setq ch (1+ ch))) | |
351 (setq i (1+ i))) | |
352 (setq deflist (cdr deflist)))) | |
353 | |
354 | |
17052 | 355 ;; Japanese character set (JISX0201-kana, JISX0201-roman, JISX0208, JISX0212) |
356 | |
357 (modify-category-entry (make-char 'katakana-jisx0201) ?k) | |
358 (modify-category-entry (make-char 'latin-jisx0201) ?r) | |
359 (modify-category-entry (make-char 'japanese-jisx0208) ?j) | |
360 (modify-category-entry (make-char 'japanese-jisx0212) ?j) | |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
361 (modify-category-entry (make-char 'katakana-jisx0201) ?\|) |
17052 | 362 (modify-category-entry (make-char 'japanese-jisx0208) ?\|) |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
363 (modify-category-entry (make-char 'japanese-jisx0212) ?\|) |
17052 | 364 |
365 ;; JISX0208 | |
366 (modify-syntax-entry (make-char 'japanese-jisx0208) "w") | |
367 (modify-syntax-entry (make-char 'japanese-jisx0208 33) "_") | |
368 (modify-syntax-entry (make-char 'japanese-jisx0208 34) "_") | |
369 (modify-syntax-entry (make-char 'japanese-jisx0208 40) "_") | |
370 (let ((chars '(?$B!<(B ?$B!+(B ?$B!,(B ?$B!3(B ?$B!4(B ?$B!5(B ?$B!6(B ?$B!7(B ?$B!8(B ?$B!9(B ?$B!:(B ?$B!;(B))) | |
371 (while chars | |
372 (modify-syntax-entry (car chars) "w") | |
373 (setq chars (cdr chars)))) | |
374 (modify-syntax-entry ?\$B!J(B "($B!K(B") | |
375 (modify-syntax-entry ?\$B!N(B "($B!O(B") | |
376 (modify-syntax-entry ?\$B!P(B "($B!Q(B") | |
377 (modify-syntax-entry ?\$B!V(B "($B!W(B") | |
378 (modify-syntax-entry ?\$B!X(B "($B!Y(B") | |
379 (modify-syntax-entry ?\$B!K(B ")$B!J(B") | |
380 (modify-syntax-entry ?\$B!O(B ")$B!N(B") | |
381 (modify-syntax-entry ?\$B!Q(B ")$B!P(B") | |
382 (modify-syntax-entry ?\$B!W(B ")$B!V(B") | |
383 (modify-syntax-entry ?\$B!Y(B ")$B!X(B") | |
384 | |
385 (modify-category-entry (make-char 'japanese-jisx0208 35) ?A) | |
386 (modify-category-entry (make-char 'japanese-jisx0208 36) ?H) | |
387 (modify-category-entry (make-char 'japanese-jisx0208 37) ?K) | |
388 (modify-category-entry (make-char 'japanese-jisx0208 38) ?G) | |
389 (modify-category-entry (make-char 'japanese-jisx0208 39) ?Y) | |
390 (let ((row 48)) | |
391 (while (< row 127) | |
392 (modify-category-entry (make-char 'japanese-jisx0208 row) ?C) | |
393 (setq row (1+ row)))) | |
17296
dc3f449803f6
Change a category of one Japanese character.
Kenichi Handa <handa@m17n.org>
parents:
17078
diff
changeset
|
394 (modify-category-entry ?$B!<(B ?K) |
dc3f449803f6
Change a category of one Japanese character.
Kenichi Handa <handa@m17n.org>
parents:
17078
diff
changeset
|
395 (let ((chars '(?$B!+(B ?$B!,(B))) |
17052 | 396 (while chars |
397 (modify-category-entry (car chars) ?K) | |
398 (modify-category-entry (car chars) ?H) | |
399 (setq chars (cdr chars)))) | |
400 (let ((chars '(?$B!3(B ?$B!4(B ?$B!5(B ?$B!6(B ?$B!7(B ?$B!8(B ?$B!9(B ?$B!:(B ?$B!;(B))) | |
401 (while chars | |
402 (modify-category-entry (car chars) ?C) | |
403 (setq chars (cdr chars)))) | |
404 | |
405 ;; JISX0212 | |
406 (modify-syntax-entry (make-char 'japanese-jisx0212) "w") | |
407 (modify-syntax-entry (make-char 'japanese-jisx0212 33) "_") | |
408 (modify-syntax-entry (make-char 'japanese-jisx0212 34) "_") | |
409 (modify-syntax-entry (make-char 'japanese-jisx0212 35) "_") | |
410 | |
411 (modify-category-entry (make-char 'japanese-jisx0212 ) ?C) | |
412 | |
413 ;; JISX0201-Kana | |
414 (modify-syntax-entry (make-char 'katakana-jisx0201) "w") | |
415 (let ((chars '(?(I!(B ?(I"(B ?(I#(B ?(I$(B ?(I%(B))) | |
416 (while chars | |
417 (modify-syntax-entry (car chars) ".") | |
418 (setq chars (cdr chars)))) | |
419 | |
420 ;; Korean character set (KSC5601) | |
421 | |
422 (modify-syntax-entry (make-char 'korean-ksc5601) "w") | |
423 (modify-syntax-entry (make-char 'korean-ksc5601 33) "_") | |
424 (modify-syntax-entry (make-char 'korean-ksc5601 34) "_") | |
425 (modify-syntax-entry (make-char 'korean-ksc5601 38) "_") | |
426 (modify-syntax-entry (make-char 'korean-ksc5601 39) "_") | |
427 (modify-syntax-entry (make-char 'korean-ksc5601 40) "_") | |
428 (modify-syntax-entry (make-char 'korean-ksc5601 41) "_") | |
429 | |
430 (modify-category-entry (make-char 'korean-ksc5601) ?h) | |
431 (modify-category-entry (make-char 'korean-ksc5601 35) ?A) | |
432 (modify-category-entry (make-char 'korean-ksc5601 37) ?G) | |
433 (modify-category-entry (make-char 'korean-ksc5601 42) ?H) | |
434 (modify-category-entry (make-char 'korean-ksc5601 43) ?K) | |
435 (modify-category-entry (make-char 'korean-ksc5601 44) ?Y) | |
436 | |
17078
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
437 ;; Lao character set |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
438 |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
439 (modify-category-entry (make-char 'lao) ?o) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
440 |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
441 (let ((deflist '(;; chars syntax category |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
442 ("(1!(B-(1N(B" "w" ?0) ; consonant |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
443 ("(1PRS]`(B-(1d(B" "w" ?1) ; vowel base |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
444 ("(1QT(B-(1W[m(B" "w" ?2) ; vowel upper |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
445 ("(1XY(B" "w" ?3) ; vowel lower |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
446 ("(1h(B-(1l(B" "w" ?4) ; tone mark |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
447 ("(1\(B" "w" ?9) ; semivowel lower |
18561
f3c28fd5118e
Modify docstring of char category
Kenichi Handa <handa@m17n.org>
parents:
18377
diff
changeset
|
448 ("(1p(B-(1y(B" "w" ?6) ; digit |
26885
c151d3ae1794
Fix cateogries of Lao symbols.
Kenichi Handa <handa@m17n.org>
parents:
26013
diff
changeset
|
449 ("(1Of(B" "_" ?5) ; symbol |
17078
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
450 )) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
451 elm chars len syntax category to ch i) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
452 (while deflist |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
453 (setq elm (car deflist)) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
454 (setq chars (car elm) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
455 len (length chars) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
456 syntax (nth 1 elm) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
457 category (nth 2 elm) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
458 i 0) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
459 (while (< i len) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
460 (if (= (aref chars i) ?-) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
461 (setq i (1+ i) |
20843 | 462 to (aref chars i)) |
463 (setq ch (aref chars i) | |
17078
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
464 to ch)) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
465 (while (<= ch to) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
466 (modify-syntax-entry ch syntax) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
467 (modify-category-entry ch category) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
468 (setq ch (1+ ch))) |
20843 | 469 (setq i (1+ i))) |
17078
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
470 (setq deflist (cdr deflist)))) |
874b471d6635
Remove prefix "coding-system-" from coding system symbol names.
Kenichi Handa <handa@m17n.org>
parents:
17071
diff
changeset
|
471 |
17052 | 472 ;; Thai character set (TIS620) |
473 | |
474 (modify-category-entry (make-char 'thai-tis620) ?t) | |
475 | |
476 (let ((deflist '(;; chars syntax category | |
477 (",T!(B-,TCEG(B-,TN(B" "w" ?0) ; consonant | |
478 (",TDFPRS`(B-,Te(B" "w" ?1) ; vowel base | |
479 (",TQT(B-,TWgn(B" "w" ?2) ; vowel upper | |
480 (",TX(B-,TZ(B" "w" ?3) ; vowel lower | |
481 (",Th(B-,Tm(B" "w" ?4) ; tone mark | |
18561
f3c28fd5118e
Modify docstring of char category
Kenichi Handa <handa@m17n.org>
parents:
18377
diff
changeset
|
482 (",Tp(B-,Ty(B" "w" ?6) ; digit |
f3c28fd5118e
Modify docstring of char category
Kenichi Handa <handa@m17n.org>
parents:
18377
diff
changeset
|
483 (",TOf_oz{(B" "_" ?5) ; symbol |
17052 | 484 )) |
485 elm chars len syntax category to ch i) | |
486 (while deflist | |
487 (setq elm (car deflist)) | |
488 (setq chars (car elm) | |
489 len (length chars) | |
490 syntax (nth 1 elm) | |
491 category (nth 2 elm) | |
492 i 0) | |
493 (while (< i len) | |
494 (if (= (aref chars i) ?-) | |
495 (setq i (1+ i) | |
20843 | 496 to (aref chars i)) |
497 (setq ch (aref chars i) | |
17052 | 498 to ch)) |
499 (while (<= ch to) | |
500 (modify-syntax-entry ch syntax) | |
501 (modify-category-entry ch category) | |
502 (setq ch (1+ ch))) | |
20843 | 503 (setq i (1+ i))) |
17052 | 504 (setq deflist (cdr deflist)))) |
505 | |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
506 ;; Tibetan character set |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
507 |
24208
6964e11724dc
Set category `q' for all characters
Kenichi Handa <handa@m17n.org>
parents:
23527
diff
changeset
|
508 (modify-category-entry (make-char 'tibetan) ?q) |
6964e11724dc
Set category `q' for all characters
Kenichi Handa <handa@m17n.org>
parents:
23527
diff
changeset
|
509 (modify-category-entry (make-char 'tibetan-1-column) ?q) |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
510 |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
511 (let ((deflist '(;; chars syntax category |
29362
038c13f83357
Fix syntax/category setting of Tibetan characters.
Kenichi Handa <handa@m17n.org>
parents:
27691
diff
changeset
|
512 ("$(7"!(B-$(7"J"K(B" "w" ?0) ; consonant |
038c13f83357
Fix syntax/category setting of Tibetan characters.
Kenichi Handa <handa@m17n.org>
parents:
27691
diff
changeset
|
513 ("$(7#!(B-$(7#J#K#L#M!"!#(B" "w" ?0) ; |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
514 ("$(7$!(B-$(7$e(B" "w" ?0) ; |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
515 ("$(7%!(B-$(7%u(B" "w" ?0) ; |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
516 ("$(7"S"["\"]"^"a(B" "w" ?2) ; upper vowel |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
517 ("$(7"_"c"d"g"h"i"j"k"l(B" "w" ?2) ; upper modifier |
29362
038c13f83357
Fix syntax/category setting of Tibetan characters.
Kenichi Handa <handa@m17n.org>
parents:
27691
diff
changeset
|
518 ("$(7!I"Q"R"U"e!e!g(B" "w" ?3) ; lowel vowel/modifier |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
519 ("$(7!P(B-$(7!Y!Z(B-$(7!c(B" "w" ?6) ; digit |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
520 ("$(7!;!=(B-$(7!B!D"`(B" "." ?|) ; line-break char |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
521 ("$(8!;!=!?!@!A!D"`(B" "." ?|) ; |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
522 ("$(7!8!;!=(B-$(7!B!D"`!m!d(B" "." ?>) ; prohibition |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
523 ("$(8!;!=!?!@!A!D"`(B" "." ?>) ; |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
524 ("$(7!0(B-$(7!:!l#R#S"f(B" "." ?<) ; prohibition |
29362
038c13f83357
Fix syntax/category setting of Tibetan characters.
Kenichi Handa <handa@m17n.org>
parents:
27691
diff
changeset
|
525 ("$(7!C!E(B-$(7!H!J(B-$(7!O!f!h(B-$(7!k!n!o#O#P(B-$(7#`(B" "." ?q) ; others |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
526 )) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
527 elm chars len syntax category to ch i) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
528 (while deflist |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
529 (setq elm (car deflist)) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
530 (setq chars (car elm) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
531 len (length chars) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
532 syntax (nth 1 elm) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
533 category (nth 2 elm) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
534 i 0) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
535 (while (< i len) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
536 (if (= (aref chars i) ?-) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
537 (setq i (1+ i) |
20843 | 538 to (aref chars i)) |
539 (setq ch (aref chars i) | |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
540 to ch)) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
541 (while (<= ch to) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
542 (modify-syntax-entry ch syntax) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
543 (modify-category-entry ch category) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
544 (setq ch (1+ ch))) |
20843 | 545 (setq i (1+ i))) |
17753
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
546 (setq deflist (cdr deflist)))) |
de6be7f3b904
Set syntax and category for Devanagari, Thai, and
Kenichi Handa <handa@m17n.org>
parents:
17296
diff
changeset
|
547 |
17052 | 548 ;; Vietnamese character set |
549 | |
550 (let ((lower (make-char 'vietnamese-viscii-lower)) | |
551 (upper (make-char 'vietnamese-viscii-upper))) | |
552 (modify-syntax-entry lower "w") | |
553 (modify-syntax-entry upper "w") | |
554 (modify-category-entry lower ?v) | |
555 (modify-category-entry upper ?v) | |
556 (modify-category-entry lower ?l) ; To make a word with | |
557 (modify-category-entry upper ?l) ; latin characters. | |
558 ) | |
559 | |
27691
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
560 (let ((tbl (standard-case-table)) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
561 (i 32)) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
562 (while (< i 128) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
563 (set-case-syntax-pair (make-char 'vietnamese-viscii-upper i) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
564 (make-char 'vietnamese-viscii-lower i) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
565 tbl) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
566 (setq i (1+ i)))) |
5ed8dd27c116
Setup case table for Vietnamese.
Kenichi Handa <handa@m17n.org>
parents:
26885
diff
changeset
|
567 |
17052 | 568 |
569 ;;; Setting word boundary. | |
570 | |
571 (setq word-combining-categories | |
572 '((?l . ?l))) | |
573 | |
574 (setq word-separating-categories ; (2-byte character sets) | |
575 '((?A . ?K) ; Alpha numeric - Katakana | |
576 (?A . ?C) ; Alpha numeric - Chinese | |
577 (?H . ?A) ; Hiragana - Alpha numeric | |
578 (?H . ?K) ; Hiragana - Katakana | |
579 (?H . ?C) ; Hiragana - Chinese | |
580 (?K . ?A) ; Katakana - Alpha numeric | |
581 (?K . ?C) ; Katakana - Chinese | |
582 (?C . ?A) ; Chinese - Alpha numeric | |
583 (?C . ?K) ; Chinese - Katakana | |
584 )) | |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
585 |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
586 |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
587 ;; For each character set, put the information of the most proper |
24782
8f65cd6729b5
Typo fixed; prefered->preferred.
Kenichi Handa <handa@m17n.org>
parents:
24256
diff
changeset
|
588 ;; coding system to encode it by `preferred-coding-system' property. |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
589 |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
590 (let ((l '((latin-iso8859-1 . iso-latin-1) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
591 (latin-iso8859-2 . iso-latin-2) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
592 (latin-iso8859-3 . iso-latin-3) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
593 (latin-iso8859-4 . iso-latin-4) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
594 (thai-tis620 . thai-tis620) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
595 (greek-iso8859-7 . greek-iso-8bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
596 (arabic-iso8859-6 . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
597 (hebrew-iso8859-8 . hebrew-iso-8bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
598 (katakana-jisx0201 . japanese-shift-jis) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
599 (latin-jisx0201 . japanese-shift-jis) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
600 (cyrillic-iso8859-5 . cyrillic-iso-8bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
601 (latin-iso8859-9 . iso-latin-5) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
602 (japanese-jisx0208-1978 . iso-2022-jp) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
603 (chinese-gb2312 . cn-gb-2312) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
604 (japanese-jisx0208 . iso-2022-jp) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
605 (korean-ksc5601 . iso-2022-kr) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
606 (japanese-jisx0212 . iso-2022-jp) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
607 (chinese-cns11643-1 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
608 (chinese-cns11643-2 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
609 (chinese-big5-1 . chinese-big5) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
610 (chinese-big5-2 . chinese-big5) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
611 (chinese-sisheng . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
612 (ipa . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
613 (vietnamese-viscii-lower . vietnamese-viscii) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
614 (vietnamese-viscii-upper . vietnamese-viscii) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
615 (arabic-digit . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
616 (arabic-1-column . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
617 (ascii-right-to-left . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
618 (lao . lao) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
619 (arabic-2-column . iso-2022-7bit) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
620 (indian-is13194 . devanagari) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
621 (indian-1-column . devanagari) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
622 (tibetan-1-column . tibetan) |
24256
47e6aa168a66
Let ethiopic use iso-2022-7bit.
Kenichi Handa <handa@m17n.org>
parents:
24208
diff
changeset
|
623 (ethiopic . iso-2022-7bit) |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
624 (chinese-cns11643-3 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
625 (chinese-cns11643-4 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
626 (chinese-cns11643-5 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
627 (chinese-cns11643-6 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
628 (chinese-cns11643-7 . iso-2022-cn) |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
629 (indian-2-column . devanagari) |
26013 | 630 (tibetan . tibetan) |
631 (latin-iso8859-14 . iso-latin-8) | |
632 (latin-iso8859-15 . iso-latin-9)))) | |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
633 (while l |
24782
8f65cd6729b5
Typo fixed; prefered->preferred.
Kenichi Handa <handa@m17n.org>
parents:
24256
diff
changeset
|
634 (put-charset-property (car (car l)) 'preferred-coding-system (cdr (car l))) |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
635 (setq l (cdr l)))) |
23493 | 636 |
637 | |
23527
06e8c3b9deec
Setup charset property nospace-between-words.
Kenichi Handa <handa@m17n.org>
parents:
23493
diff
changeset
|
638 ;; Setup auto-fill-chars for charsets that should invoke auto-filling. |
06e8c3b9deec
Setup charset property nospace-between-words.
Kenichi Handa <handa@m17n.org>
parents:
23493
diff
changeset
|
639 ;; SPACE and NEWLIE are already set. Also put `nospace-between-words' |
06e8c3b9deec
Setup charset property nospace-between-words.
Kenichi Handa <handa@m17n.org>
parents:
23493
diff
changeset
|
640 ;; property to the charsets. |
23493 | 641 (let ((l '(katakana-jisx0201 |
642 japanese-jisx0208 japanese-jisx0212 | |
643 chinese-gb2312 chinese-big5-1 chinese-big5-2))) | |
644 (while l | |
645 (aset auto-fill-chars (make-char (car l)) t) | |
23527
06e8c3b9deec
Setup charset property nospace-between-words.
Kenichi Handa <handa@m17n.org>
parents:
23493
diff
changeset
|
646 (put-charset-property (car l) 'nospace-between-words t) |
23493 | 647 (setq l (cdr l)))) |
20734
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
648 |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
649 ;;; Local Variables: |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
650 ;;; coding: iso-2022-7bit |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
651 ;;; End: |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
652 |
179dbdbc3882
Put `prefered-coding-system'
Kenichi Handa <handa@m17n.org>
parents:
20247
diff
changeset
|
653 ;;; end of characters.el |