comparison lisp/mule/thai-xtis.el @ 422:95016f13131a r21-2-19

Import from CVS: tag r21-2-19
author cvs
date Mon, 13 Aug 2007 11:25:01 +0200
parents e804706bfb8c
children
comparison
equal deleted inserted replaced
421:fff06e11db74 422:95016f13131a
1 ;;; thai-xtis.el --- Thai support for pre-composed font (for XTIS). 1 ;;; thai-xtis.el --- Support for Thai (XTIS) -*- coding: iso-2022-7bit; -*-
2 2
3 ;; Copyright (C) 1999 Electrotechnical Laboratory, JAPAN. 3 ;; Copyright (C) 1999 Electrotechnical Laboratory, JAPAN.
4 ;; Licensed to the Free Software Foundation. 4 ;; Licensed to the Free Software Foundation.
5 5
6 ;; Author: TAKAHASHI Naoto <ntakahas@etl.go.jp> 6 ;; Author: TAKAHASHI Naoto <ntakahas@etl.go.jp>
33 ;; Virach Sornlertlamvanich <virach@links.nectec.or.th> is supported. 33 ;; Virach Sornlertlamvanich <virach@links.nectec.or.th> is supported.
34 34
35 ;;; Code: 35 ;;; Code:
36 36
37 (when (featurep 'xemacs) 37 (when (featurep 'xemacs)
38 (make-charset 'thai-xtis "Precomposed Thai (XTIS by Virach)." 38 (let ((deflist '(;; chars syntax
39 '(registry "xtis-0" 39 ("$(?!0(B-$(?NxP0R0S0`0(B-$(?e0(B" "w")
40 dimension 2 40 ("$(?p0(B-$(?y0(B" "w")
41 columns 1 41 ("$(?O0f0_0o0z0{0(B" "_")
42 chars 94 42 ))
43 final ?? 43 elm chars len syntax to ch i)
44 graphic 0)) 44 (while deflist
45 45 (setq elm (car deflist))
46 (modify-syntax-entry 'thai-xtis "w") 46 (setq chars (car elm)
47 47 len (length chars)
48 (define-category ?T "Precomposed Thai character.") 48 syntax (nth 1 elm)
49 (modify-category-entry 'thai-xtis ?T) 49 i 0)
50 (while (< i len)
51 (if (= (aref chars i) ?-)
52 (setq i (1+ i)
53 to (nth 1 (split-char (aref chars i))))
54 (setq ch (nth 1 (split-char (aref chars i)))
55 to ch))
56 (while (<= ch to)
57 (modify-syntax-entry (vector 'thai-xtis ch) syntax)
58 (setq ch (1+ ch)))
59 (setq i (1+ i)))
60 (setq deflist (cdr deflist))))
61
62 (put-charset-property 'thai-xtis 'preferred-coding-system 'tis-620)
50 ) 63 )
51 64
52 65 ;; This is the ccl-decode-thai-xtis automaton.
53 (defvar leading-code-private-21 #x9F) 66 ;;
54 67 ;; "WRITE x y" == (insert (make-char 'thai-xtis x y))
55 (defconst thai-xtis-leading-code 68 ;; "write x" == (insert x)
56 (concat (char-to-string leading-code-private-21) 69 ;; rx' == (tis620-to-thai-xtis-second-byte-bitpattern rx)
57 (char-to-string (charset-id 'thai-xtis)))) 70 ;; r3 == "no vower nor tone"
71 ;; r4 == (charset-id 'thai-xtis)
72 ;;
73 ;; | input (= r0)
74 ;; state |--------------------------------------------
75 ;; | consonant | vowel | tone
76 ;; ---------+-------------+-------------+----------------
77 ;; r1 == 0 | r1 = r0 | WRITE r0,r3 | WRITE r0,r3
78 ;; r2 == 0 | | |
79 ;; ---------+-------------+-------------+----------------
80 ;; r1 == C | WRITE r1,r3 | r2 = r0' | WRITE r1,r3|r0'
81 ;; r2 == 0 | r1 = r0 | | r1 = 0
82 ;; ---------+-------------+-------------+----------------
83 ;; r1 == C | WRITE r1,r2 | WRITE r1,r2 | WRITE r1,r2|r0'
84 ;; r2 == V | r1 = r0 | WRITE r0,r3 | r1 = r2 = 0
85 ;; | r2 = 0 | r1 = r2 = 0 |
86 ;;
87 ;;
88 ;; | input (= r0)
89 ;; state |-----------------------------------------
90 ;; | symbol | ASCII | EOF
91 ;; ---------+-------------+-------------+-------------
92 ;; r1 == 0 | WRITE r0,r3 | write r0 |
93 ;; r2 == 0 | | |
94 ;; ---------+-------------+-------------+-------------
95 ;; r1 == C | WRITE r1,r3 | WRITE r1,r3 | WRITE r1,r3
96 ;; r2 == 0 | WRITE r0,r3 | write r0 |
97 ;; | r1 = 0 | r1 = 0 |
98 ;; ---------+-------------+-------------+-------------
99 ;; r1 == C | WRITE r1,r2 | WRITE r1,r2 | WRITE r1,r2
100 ;; r2 == V | WRITE r0,r3 | write r0 |
101 ;; | r1 = r2 = 0 | r1 = r2 = 0 |
102
103
104 (eval-and-compile
105
106 ;; input : r5 = 1st byte, r6 = 2nd byte
107 ;; Their values will be destroyed.
108 (define-ccl-program ccl-thai-xtis-write
109 '(0
110 ((r5 = ((r5 & #x7F) << 7))
111 (r6 = ((r6 & #x7F) | r5))
112 (write-multibyte-character r4 r6))))
58 113
59 (define-ccl-program ccl-thai-xtis-consonant 114 (define-ccl-program ccl-thai-xtis-consonant
60 `(0 115 '(0
61 (if (r1 == 0) 116 (if (r1 == 0)
62 ((write ,thai-xtis-leading-code) 117 (r1 = r0)
63 (write r0) 118 (if (r2 == 0)
64 (r1 = r2)) 119 ((r5 = r1) (r6 = r3) (call ccl-thai-xtis-write)
65 (if (r1 == r2) 120 (r1 = r0))
66 ((write r1) 121 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write)
67 (write ,thai-xtis-leading-code) 122 (r1 = r0)
68 (write r0)) 123 (r2 = 0))))))
69 ((write r1) 124
70 (write ,thai-xtis-leading-code) 125 (define-ccl-program ccl-thai-xtis-vowel
71 (write r0) 126 '(0
72 (r1 = r2)))))) 127 ((if (r1 == 0)
128 ((r5 = r0) (r6 = r3) (call ccl-thai-xtis-write))
129 ((if (r2 == 0)
130 (r2 = ((r0 - 204) << 3))
131 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write)
132 (r5 = r0) (r6 = r3) (call ccl-thai-xtis-write)
133 (r1 = 0)
134 (r2 = 0))))))))
73 135
74 (define-ccl-program ccl-thai-xtis-vowel-d1 136 (define-ccl-program ccl-thai-xtis-vowel-d1
75 `(0 137 '(0
138 ((if (r1 == 0)
139 ((r5 = r0) (r6 = r3) (call ccl-thai-xtis-write))
140 ((if (r2 == 0)
141 (r2 = #x38)
142 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write)
143 (r5 = r0) (r6 = r3) (call ccl-thai-xtis-write)
144 (r1 = 0)
145 (r2 = 0))))))))
146
147 (define-ccl-program ccl-thai-xtis-vowel-ee
148 '(0
149 ((if (r1 == 0)
150 ((r5 = r0) (r6 = r3) (call ccl-thai-xtis-write))
151 ((if (r2 == 0)
152 (r2 = #x78)
153 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write)
154 (r5 = r0) (r6 = r3) (call ccl-thai-xtis-write)
155 (r1 = 0)
156 (r2 = 0))))))))
157
158 (define-ccl-program ccl-thai-xtis-tone
159 '(0
76 (if (r1 == 0) 160 (if (r1 == 0)
77 ((write ,thai-xtis-leading-code) 161 ((r5 = r0) (r6 = r3) (call ccl-thai-xtis-write))
78 (write r0 r2)) 162 (if (r2 == 0)
79 (if (r1 == r2) 163 ((r5 = r1) (r6 = ((r0 - #xE6) | r3)) (call ccl-thai-xtis-write)
80 (r1 = ?\xb8) 164 (r1 = 0))
81 ((write r1) 165 ((r5 = r1) (r6 = ((r0 - #xE6) | r2)) (call ccl-thai-xtis-write)
82 (write ,thai-xtis-leading-code) 166 (r1 = 0)
83 (write r0 r2) 167 (r2 = 0))))))
84 (r1 = 0)))))) 168
85 169 (define-ccl-program ccl-thai-xtis-symbol
86 (define-ccl-program ccl-thai-xtis-vowel 170 '(0
87 `(0
88 (if (r1 == 0) 171 (if (r1 == 0)
89 ((write ,thai-xtis-leading-code) 172 ((r5 = r0) (r6 = r3) (call ccl-thai-xtis-write))
90 (write r0 r2)) 173 (if (r2 == 0)
91 (if (r1 == r2) 174 ((r5 = r1) (r6 = r3) (call ccl-thai-xtis-write)
92 (r1 = ((r0 - 188) << 3)) 175 (r5 = r0) (r6 = r3) (call ccl-thai-xtis-write)
93 ((write r1) 176 (r1 = 0))
94 (write ,thai-xtis-leading-code) 177 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write)
95 (write r0 r2) 178 (r5 = r0) (r6 = r3) (call ccl-thai-xtis-write)
96 (r1 = 0)))))) 179 (r1 = 0)
97 180 (r2 = 0))))))
98 (define-ccl-program ccl-thai-xtis-vowel-ee 181
99 `(0 182 (define-ccl-program ccl-thai-xtis-ascii
183 '(0
100 (if (r1 == 0) 184 (if (r1 == 0)
101 ((write ,thai-xtis-leading-code) 185 (write r0)
102 (write r0 r2)) 186 (if (r2 == 0)
103 (if (r1 == r2) 187 ((r5 = r1) (r6 = r3) (call ccl-thai-xtis-write)
104 (r1 = ?\xf8)
105 ((write r1)
106 (write ,thai-xtis-leading-code)
107 (write r0 r2)
108 (r1 = 0))))))
109
110 (define-ccl-program ccl-thai-xtis-tone
111 `(0
112 (if (r1 == 0)
113 ((write ,thai-xtis-leading-code)
114 (write r0 r2))
115 (if (r1 == r2)
116 ((r0 -= 54)
117 (write r0) 188 (write r0)
118 (r1 = 0)) 189 (r1 = 0))
119 ((r1 += (r0 - ?\xe6)) 190 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write)
120 (write r1) 191 (write r0)
121 (r1 = 0)))))) 192 (r1 = 0)
122 193 (r2 = 0))))))
123 (define-ccl-program ccl-thai-xtis-symbol 194
124 `(0 195 (define-ccl-program ccl-thai-xtis-eof
125 (if (r1 == 0) 196 '(0
126 ((write ,thai-xtis-leading-code) 197 (if (r1 != 0)
127 (write r0 r2)) 198 (if (r2 == 0)
128 (if (r1 == r2) 199 ((r5 = r1) (r6 = r3) (call ccl-thai-xtis-write))
129 ((write r2) 200 ((r5 = r1) (r6 = r2) (call ccl-thai-xtis-write))))))
130 (write ,thai-xtis-leading-code)
131 (write r0 r2)
132 (r1 = 0))
133 ((write r1)
134 (write ,thai-xtis-leading-code)
135 (write r0 r2)
136 (r1 = 0))))))
137 201
138 (define-ccl-program ccl-decode-thai-xtis 202 (define-ccl-program ccl-decode-thai-xtis
139 `(4 203 `(4
140 ((read r0) 204 ((read r0)
141 (r1 = 0) 205 (r1 = 0)
142 (r2 = ?\xb0) 206 (r2 = 0)
207 (r3 = #x30)
208 (r4 = ,(charset-id 'thai-xtis))
143 (loop 209 (loop
144 (if (r0 < 161) 210 (if (r0 < 161)
145 (if (r1 == 0) 211 (call ccl-thai-xtis-ascii)
146 (write r0)
147 (if (r1 == r2)
148 ((write r2 r0)
149 (r1 = 0))
150 ((write r1 r0)
151 (r1 = 0))))
152 (branch (r0 - 161) 212 (branch (r0 - 161)
153 (call ccl-thai-xtis-consonant) 213 (call ccl-thai-xtis-consonant)
154 (call ccl-thai-xtis-consonant) 214 (call ccl-thai-xtis-consonant)
155 (call ccl-thai-xtis-consonant) 215 (call ccl-thai-xtis-consonant)
156 (call ccl-thai-xtis-consonant) 216 (call ccl-thai-xtis-consonant)
245 nil 305 nil
246 nil)) 306 nil))
247 (read r0) 307 (read r0)
248 (repeat))) 308 (repeat)))
249 309
250 (if (r1 != 0) 310 (call ccl-thai-xtis-eof)))
251 (write r1) 311
252 nil))) 312 )
313
314 (defconst leading-code-private-21 #x9F)
253 315
254 (define-ccl-program ccl-encode-thai-xtis 316 (define-ccl-program ccl-encode-thai-xtis
255 `(1 317 `(1
256 ((read r0) 318 ((read r0)
257 (loop 319 (loop
260 (if (r1 == ,(charset-id 'thai-xtis)) 322 (if (r1 == ,(charset-id 'thai-xtis))
261 ((read r0) 323 ((read r0)
262 (write r0) 324 (write r0)
263 (read r0) 325 (read r0)
264 (r1 = (r0 & 7)) 326 (r1 = (r0 & 7))
265 (r0 = ((r0 - ?\xb0) >> 3)) 327 (r0 = ((r0 - #xB0) >> 3))
266 (if (r0 != 0) 328 (if (r0 != 0)
267 (write r0 [0 209 212 213 214 215 216 217 218 238])) 329 (write r0 [0 209 212 213 214 215 216 217 218 238]))
268 (if (r1 != 0) 330 (if (r1 != 0)
269 (write r1 [0 231 232 233 234 235 236 237])) 331 (write r1 [0 231 232 233 234 235 236 237]))
270 (read r0) 332 (read r0)
273 (read r0) 335 (read r0)
274 (repeat)))) 336 (repeat))))
275 (write-read-repeat r0)))))) 337 (write-read-repeat r0))))))
276 338
277 (if (featurep 'xemacs) 339 (if (featurep 'xemacs)
278 (make-coding-system 340 (progn
279 'tis-620 'ccl 341 (make-coding-system
280 "external=tis620, internal=thai-xtis" 342 'tis-620 'ccl
281 `(mnemonic "TIS620" 343 "external=tis620, internal=thai-xtis"
282 decode ,ccl-decode-thai-xtis 344 `(mnemonic "TIS620"
283 encode ,ccl-encode-thai-xtis)) 345 decode ,ccl-decode-thai-xtis
346 encode ,ccl-encode-thai-xtis))
347 (coding-system-put 'tis-620 'category 'iso-8-1))
284 (make-coding-system 348 (make-coding-system
285 'tis-620 4 ?T "external=tis620, internal=thai-xtis" 349 'tis-620 4 ?T "external=tis620, internal=thai-xtis"
286 '(ccl-decode-thai-xtis . ccl-encode-thai-xtis) 350 '(ccl-decode-thai-xtis . ccl-encode-thai-xtis)
287 '((safe-charsets . t))) 351 '((safe-charsets . t)))
288 ) 352 )
289 353
290 354
291 (set-language-info-alist 355 (set-language-info-alist
292 "Thai-XTIS" 356 "Thai-XTIS"
293 '((setup-function . setup-thai-xtis-environment) 357 '((charset thai-xtis)
294 (exit-function . exit-thai-xtis-environment)
295 (charset thai-xtis)
296 (coding-system tis-620 iso-2022-7bit) 358 (coding-system tis-620 iso-2022-7bit)
359 (tutorial . "TUTORIAL.th")
360 (tutorial-coding-system . tis-620)
297 (coding-priority tis-620 iso-2022-7bit) 361 (coding-priority tis-620 iso-2022-7bit)
298 (sample-text . "$(?!:(B") 362 (sample-text . "$(?!:(B")
299 (documentation . t))) 363 (documentation . t)))
300 364
301 ;; thai-xtis.el ends here. 365 ;; thai-xtis.el ends here.