annotate lisp/language/knd-util.el @ 90017:6e012bc03071

(Fcall_process): Fix merging of 2004-10-13 change.
author Kenichi Handa <handa@m17n.org>
date Thu, 14 Oct 2004 12:28:46 +0000
parents 68c22ea6027c
children f9a65d7ebd29
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
89909
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1 ;;; knd-util.el --- Support for composing Kannada characters
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3 ;; Copyright (C) 2003 Free Software Foundation, Inc.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
5 ;; Maintainer: Maintainer: CHOWKSEY, Kailash C. <klchxbec@m-net.arbornet.org>
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
6 ;; Keywords: multilingual, Kannada
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
7
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
9
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
12 ;; the Free Software Foundation; either version 2, or (at your option)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
13 ;; any later version.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
14
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
18 ;; GNU General Public License for more details.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
19
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
23 ;; Boston, MA 02111-1307, USA.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
24
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
25 ;; Created: Jul. 14. 2003
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
26
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
27 ;;; Commentary:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
28
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
29 ;; This file provides character(Unicode) to glyph(CDAC) conversion and
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
30 ;; composition of Kannada script characters.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
31
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
32 ;;; Code:
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
33
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
34 ;;;###autoload
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
35
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
36 ;; Kannada Composable Pattern
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
37 ;; C .. Consonants
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
38 ;; V .. Vowel
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
39 ;; H .. Virama
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
40 ;; M .. Matra
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
41 ;; V .. Vowel
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
42 ;; (N .. Zerowidth Non Joiner)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
43 ;; (J .. Zerowidth Joiner. )
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
44 ;; 1. vowel
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
45 ;; V(A)?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
46 ;; 2. syllable : maximum of 5 consecutive consonants. (e.g. kartsnya)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
47 ;; ((CH)?(CH)?(CH)?CH)?C(H|M?)?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
48
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
49 (defconst kannada-consonant
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
50 "[$,1>u(B-$,1?9(B]")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
51
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
52 (defconst kannada-consonant-needs-twirl
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
53 "[$,1>u>w(B-$,1>{>}(B-$,1>~? (B-$,1?"?$(B-$,1?+?-?0?3(B-$,1?9(B]\\($,1?M(B[$,1>u(B-$,1?9(B]\\)*[$,1?A?B?C?D>b(B]?$")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
54
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
55 (defconst kannada-composable-pattern
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
56 (concat
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
57 "\\([$,1>b(B-$,1>t?`>l(B]\\)\\|[$,1>c(B]"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
58 "\\|\\("
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
59 "\\(?:\\(?:[$,1>u(B-$,1?9(B]$,1?M(B\\)?\\(?:[$,1>u(B-$,1?9(B]$,1?M(B\\)?\\(?:[$,1>u(B-$,1?9(B]$,1?M(B\\)?[$,1>u(B-$,1?9(B]$,1?M(B\\)?"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
60 "[$,1>u(B-$,1?9(B]\\(?:$,1?M(B\\|[$,1?>(B-$,1?M?U?C(B]?\\)?"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
61 "\\)")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
62 "Regexp matching a composable sequence of Kannada characters.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
63
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
64 ;;;###autoload
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
65 (defun kannada-compose-region (from to)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
66 (interactive "r")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
67 (save-excursion
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
68 (save-restriction
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
69 (narrow-to-region from to)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
70 (goto-char (point-min))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
71 (while (re-search-forward kannada-composable-pattern nil t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
72 (kannada-compose-syllable-region (match-beginning 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
73 (match-end 0))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
74 ;;;###autoload
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
75 (defun kannada-compose-string (string)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
76 (with-temp-buffer
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
77 (insert (decompose-string string))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
78 (kannada-compose-region (point-min) (point-max))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
79 (buffer-string)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
80
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
81 ;;;###autoload
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
82 (defun kannada-post-read-conversion (len)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
83 (save-excursion
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
84 (save-restriction
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
85 (let ((buffer-modified-p (buffer-modified-p)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
86 (narrow-to-region (point) (+ (point) len))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
87 (kannada-compose-region (point-min) (point-max))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
88 (set-buffer-modified-p buffer-modified-p)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
89 (- (point-max) (point-min))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
90
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
91 (defun kannada-range (from to)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
92 "Make the list of the integers of range FROM to TO."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
93 (let (result)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
94 (while (<= from to) (setq result (cons to result) to (1- to))) result))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
95
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
96 (defun kannada-regexp-of-hashtbl-keys (hashtbl)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
97 "Return a regular expression that matches all keys in hashtable HASHTBL."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
98 (let ((max-specpdl-size 1000))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
99 (regexp-opt
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
100 (sort
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
101 (let (dummy)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
102 (maphash (function (lambda (key val) (setq dummy (cons key dummy)))) hashtbl)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
103 dummy)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
104 (function (lambda (x y) (> (length x) (length y))))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
105
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
106 (defun kannada-regexp-of-hashtbl-vals (hashtbl)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
107 "Return a regular expression that matches all values in hashtable HASHTBL."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
108 (let ((max-specpdl-size 1000))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
109 (regexp-opt
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
110 (sort
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
111 (let (dummy)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
112 (maphash (function (lambda (key val) (setq dummy (cons val dummy)))) hashtbl)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
113 dummy)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
114 (function (lambda (x y) (> (length x) (length y))))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
115
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
116 ;;;###autoload
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
117 (defun kannada-composition-function (pos &optional string)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
118 "Compose Kannada characters after the position POS.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
119 If STRING is not nil, it is a string, and POS is an index to the string.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
120 In this case, compose characters after POS of the string."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
121 (if string
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
122 ;; Not yet implemented.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
123 nil
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
124 (goto-char pos)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
125 (if (looking-at kannada-composable-pattern)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
126 (prog1 (match-end 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
127 (kannada-compose-syllable-region pos (match-end 0))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
128
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
129 ;; Notes on conversion steps.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
130
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
131 ;; 1. chars to glyphs
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
132 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
133 ;; Rules will not be applied to the virama appeared at the end of the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
134 ;; text. Also, the preceding/following "r" will be treated as special case.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
135
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
136 ;; 2. glyphs reordering.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
137 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
138 ;; The glyphs are split by virama, and each glyph groups are
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
139 ;; re-ordered in the following order.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
140 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
141 ;; Note that `consonant-glyph' mentioned here does not contain the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
142 ;; vertical bar (right modifier) attached at the right of the
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
143 ;; consonant.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
144 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
145 ;; If the glyph-group contains right modifier,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
146 ;; (1) consonant-glyphs/vowels
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
147 ;; (2) spacing
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
148 ;; (3) right modifier (may be matra)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
149 ;; (4) top matra
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
150 ;; (5) preceding "r"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
151 ;; (7) following "r"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
152 ;; (8) bottom matra or virama.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
153 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
154 ;; Otherwise,
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
155 ;; (1) consonant-glyph/vowels, with nukta sign
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
156 ;; (3) left matra
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
157 ;; (4) top matra
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
158 ;; (5) preceding "r"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
159 ;; (7) following "r"
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
160 ;; (8) bottom matra or virama.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
161 ;; (2) spacing
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
162
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
163 ;; 3. glyph to glyph
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
164 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
165 ;; For better display, some glyph display would be tuned.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
166
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
167 ;; 4. Composition.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
168 ;;
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
169 ;; left modifiers will be attached at the left.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
170 ;; others will be attached right.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
171
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
172 ;; Problem::
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
173 ;; Can we generalize this methods to other Indian scripts?
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
174
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
175 (defvar knd-char-glyph
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
176 '(("$,1>e(B" . "$,43@(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
177 ("$,1>f(B" . "$,43A(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
178 ("$,1?>(B" . "$,44{(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
179 ("$,1>g(B" . "$,43B(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
180 ("$,1??(B" . nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
181 ("$,1>h(B" . "$,43C(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
182 ("$,1?@(B" . nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
183 ("$,1>i(B" . "$,43D(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
184 ("$,1?A(B" . "\$,44(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
185 ("$,1>j(B" . "$,43E(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
186 ("$,1?B(B" . "\$,45 (B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
187 ("$,1>k(B" . "$,43F4(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
188 ("$,1?C(B" . "\$,45$(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
189 ("$,1?`(B" . "$,43F5 (B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
190 ("$,1?D(B" . "\$,45%(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
191 ;;("$,1>l(B" . nil) ; not implemented.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
192 ;;("$,1?a(B" . nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
193 ("$,1>n(B" . "$,43G(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
194 ("$,1>o(B" . "$,43H(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
195 ("$,1>p(B" . "$,43I(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
196 ("$,1?F(B" . "\$,45&(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
197 ("$,1?G(B" . "\$,45&4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
198 ("$,1?H(B" . "\$,45&5'(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
199 ("$,1>r(B" . "$,43J(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
200 ("$,1?J(B" . "$,45&5 (B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
201 ("$,1>s(B" . "$,43K(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
202 ("$,1?K(B" . "\$,45&5 4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
203 ("$,1>t(B" . "$,43L(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
204 ("$,1?L(B" . "\$,45((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
205 ("$,1>b(B" . "$,43M(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
206 ("$,1>c(B" . "$,43N(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
207 ("$,1>u?M(B" . "$,43O5)(B") ("$,1>u(B" . "$,43O(B") ("$,1>u??(B" . "$,43P(B") ("$,1>u?@(B" . "$,43P4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
208 ("$,1>v?M(B" . "$,43S5)(B") ("$,1>v(B" . "$,43S(B") ("$,1>v??(B" . "$,43T(B") ("$,1>v?@(B" . "$,43T4~(B") ("$,1>v?F(B" . "$,43S5&(B") ("$,1>v?G(B" . "$,43S5&4~(B") ("$,1>v?H(B" . "$,43S5&5'(B") ("$,1>v?J(B" . "$,43S5&5&5 (B") ("$,1>v?K(B" . "$,43S5&5&5 4~(B") ("$,1>v?L(B" . "$,43S5((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
209 ("$,1>w?M(B" . "$,43V5)(B") ("$,1>w(B" . "$,43V(B") ("$,1>w??(B" . "$,43W(B") ("$,1>w?@(B" . "$,43W4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
210 ("$,1>x?M(B" . "$,43Y5)(B") ("$,1>x(B" . "$,43Y(B") ("$,1>x??(B" . "$,43Z(B") ("$,1>x?@(B" . "$,43Z4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
211 ("$,1>y?M(B" . "$,43\5)(B") ("$,1>y(B" . "$,43\(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
212 ("$,1>z?M(B" . "$,43^5)(B") ("$,1>z(B" . "$,43^(B") ("$,1>z??(B" . "$,43_(B") ("$,1>z?@(B" . "$,43_4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
213 ("$,1>{?M(B" . "$,43a5)(B") ("$,1>{(B" . "$,43a(B") ("$,1>{??(B" . "$,43b(B") ("$,1>{?@(B" . "$,43b4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
214 ("$,1>|?M(B" . "$,43d5)(B") ("$,1>|(B" . "$,43d(B") ("$,1>|??(B" . "$,43f(B") ("$,1>|?@(B" . "$,43f4~(B") ("$,1>|?F(B" . "$,43e5&(B") ("$,1>|?G(B" . "$,43e5&4~(B") ("$,1>|?H(B" . "$,43e5&5'(B") ("$,1>|?J(B" . "$,43e5&5&5 (B") ("$,1>|?K(B" . "$,43e5&5&5 4~(B") ("$,1>|?L(B" . "$,43e5((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
215 ("$,1>}?M(B" . "$,44a4z3h45)(B") ("$,1>}(B" . "$,44a4z3h4(B") ("$,1>}??(B" . "$,44b3h4(B") ("$,1>}?@(B" . "$,44b3h44~(B") ("$,1>}?B(B". "$,44a4z3h5 (B") ("$,1>}?J(B". "$,44a5&3h5 (B") ("$,1>}?K(B". "$,44a5&3h5 4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
216 ("$,1>~?M(B" . "$,43j5)(B") ("$,1>~(B" . "$,43j(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
217 ("$,1>?M(B" . "$,43m5)(B") ("$,1>(B" . "$,43l(B") ("$,1?#?>(B" . "$,43m4{(B") ("$,1>??(B" . "$,43n(B") ("$,1>?@(B" . "$,43n4~(B") ("$,1>?F(B" . "$,43m5&(B") ("$,1>?G(B" . "$,43m5&4~(B") ("$,1>?H(B" . "$,43m5&5'(B") ("$,1>?J(B" . "$,43m5&5&5 (B") ("$,1>?K(B" . "$,43m5&5&5 4~(B") ("$,1>?L(B" . "$,43m5((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
218 ("$,1? ?M(B" . "$,43p5)(B") ("$,1? (B" . "$,43p(B") ("$,1? ??(B" . "$,43q(B") ("$,1? ?@(B" . "$,43q4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
219 ("$,1?!?M(B" . "$,43s5)(B") ("$,1?!(B" . "$,43s(B") ("$,1?!??(B" . "$,43t(B") ("$,1?!?@(B" . "$,43t4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
220 ("$,1?"?M(B" . "$,43v5)(B") ("$,1?"(B" . "$,43v(B") ("$,1?"??(B" . "$,43w(B") ("$,1?"?@(B" . "$,43w4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
221 ("$,1?#?M(B" . "$,43z5)(B") ("$,1?#(B" . "$,43y(B") ("$,1?#?>(B" . "$,43z4{(B") ("$,1?#??(B" . "$,43{(B") ("$,1?#?@(B" . "$,43{4~(B") ("$,1?#?F(B" . "$,43z5&(B") ("$,1?#?G(B" . "$,43z5&4~(B") ("$,1?#?H(B" . "$,43z5&5'(B") ("$,1?#?J(B" . "$,43z5&5&5 (B") ("$,1?#?K(B" . "$,43z5&5&5 4~(B") ("$,1?#?L(B" . "$,43z5((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
222 ("$,1?$?M(B" . "$,43}5)(B") ("$,1?$(B" . "$,43}(B") ("$,1?$??(B" . "$,43~(B") ("$,1?$?@(B" . "$,43~4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
223 ("$,1?%?M(B" . "$,44B5)(B") ("$,1?%(B" . "$,44B(B") ("$,1?%??(B" . "$,44C(B") ("$,1?%?@(B" . "$,44C4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
224 ("$,1?&?M(B" . "$,44E5)(B") ("$,1?&(B" . "$,44E(B") ("$,1?&??(B" . "$,44F(B") ("$,1?&?@(B" . "$,44F4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
225 ("$,1?'?M(B" . "$,44H5)(B") ("$,1?'(B" . "$,44H(B") ("$,1?'??(B" . "$,44I(B") ("$,1?'?@(B" . "$,44I4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
226 ("$,1?(?M(B" . "$,44K5)(B") ("$,1?((B" . "$,44K(B") ("$,1?(??(B" . "$,44L(B") ("$,1?(?@(B" . "$,44L4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
227 ("$,1?*?M(B" . "$,44N5)(B") ("$,1?*(B" . "$,44N(B") ("$,1?*??(B" . "$,44O(B") ("$,1?*?@(B" . "$,44O4~(B") ("$,1?*?A(B" . "$,44N5"(B") ("$,1?*?B(B" . "$,44N5#(B") ("$,1?*?J(B" . "$,44N5&5#(B") ("$,1?*?K(B" . "$,44N5&5#4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
228 ("$,1?+?M(B" . "$,44Q5)(B") ("$,1?+(B" . "$,44Q(B") ("$,1?+??(B" . "$,44R(B") ("$,1?+?@(B" . "$,44R4~(B") ("$,1?+?A(B" . "$,44Q5"(B") ("$,1?+?B(B" . "$,44Q5#(B") ("$,1?+?J(B" . "$,44Q5&5#(B") ("$,1?+?K(B" . "$,44Q5&5#4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
229 ("$,1?,?M(B" . "$,44W5)(B") ("$,1?,(B" . "$,44V(B") ("$,1?,?>(B". "$,44W4{(B") ("$,1?,??(B" . "$,44X(B") ("$,1?,?@(B" . "$,44X4~(B") ("$,1?,?F(B" . "$,44W5&(B") ("$,1?,?G(B" . "$,44W5&4~(B") ("$,1?,?H(B" . "$,44W5&5'(B") ("$,1?,?J(B" . "$,44W5&5&5 (B") ("$,1?,?K(B" . "$,44W5&5&5 4~(B") ("$,1?,?L(B" . "$,44W5((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
230 ("$,1?-?M(B" . "$,44Z5)(B") ("$,1?-(B" . "$,44Z(B") ("$,1?-??(B" . "$,44[(B") ("$,1?-?@(B" . "$,44[4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
231 ("$,1?.?M(B" . "$,44h5!5)(B") ("$,1?.(B" . "$,44h4z4(B") ("$,1?.?>(B" . "$,44h4z5!4{(B") ("$,1?.??(B" . "$,44i4(B") ("$,1?.?@(B" . "$,44i44~(B") ("$,1?.?J(B". "$,44h5&5 (B") ("$,1?.?K(B". "$,44h5&5 4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
232 ("$,1?/?M(B" . "$,44^4z5!5)(B") ("$,1?/(B" . "$,44^4z4(B") ("$,1?/?>(B" . "$,44^4z5!4{(B")("$,1?/??(B" . "$,44_4(B") ("$,1?/?@(B" . "$,44_44~(B") ("$,1?/?J(B" . "$,44^5&5 (B") ("$,1?/?K(B" . "$,44^5&5 4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
233 ("$,1?0?M(B" . "$,44a5)(B") ("$,1?0(B" . "$,44a(B") ("$,1?0??(B" . "$,44b(B") ("$,1?0?@(B" . "$,44b4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
234 ("$,1?0?M(B" . "$,44a5)(B") ("$,1?0(B" . "$,44a(B") ("$,1?0??(B" . "$,44b(B") ("$,1?0?@(B" . "$,44b4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
235 ("$,1?2?M(B" . "$,44e5)(B") ("$,1?2(B" . "$,44d(B") ("$,1?2?>(B" . "$,44e4{(B") ("$,1?2??(B" . "$,44f(B") ("$,1?2?@(B" . "$,44f4~(B") ("$,1?2?F(B" . "$,44e5&(B") ("$,1?2?G(B" . "$,44e5&4~(B") ("$,1?2?H(B" . "$,44e5&5'(B") ("$,1?2?J(B" . "$,44e5&5&5 (B") ("$,1?2?K(B" . "$,44e5&5&5 4~(B") ("$,1?2?L(B" . "$,44e5((B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
236 ("$,1?5?M(B" . "$,44h5)(B") ("$,1?5(B" . "$,44h(B") ("$,1?5??(B" . "$,44i(B") ("$,1?5?@(B" . "$,44i4~(B") ("$,1?5?A(B" . "$,44h5"(B") ("$,1?5?B(B" . "$,44h5#(B") ("$,1?5?J(B" . "$,44h5&5#(B") ("$,1?5?K(B" . "$,44h5&5#4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
237 ("$,1?6?M(B" . "$,44k5)(B") ("$,1?6(B" . "$,44k(B") ("$,1?6??(B" . "$,44l(B") ("$,1?6?@(B" . "$,44l4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
238 ("$,1?7?M(B" . "$,44n5)(B") ("$,1?7(B" . "$,44n(B") ("$,1?7??(B" . "$,44o(B") ("$,1?7?@(B" . "$,44o4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
239 ("$,1?8?M(B" . "$,44q5)(B") ("$,1?8(B" . "$,44q(B") ("$,1?8??(B" . "$,44r(B") ("$,1?8?@(B" . "$,44r4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
240 ("$,1?9?M(B" . "$,44t5)(B") ("$,1?9(B" . "$,44t(B") ("$,1?9??(B" . "$,44u(B") ("$,1?9?@(B" . "$,44u4~(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
241 ("$,1?3?M(B" . "$,44w5)(B") ("$,1?3(B" . "$,44w(B") ("$,1?3??(B" . "$,44x(B") ("$,1?3?@(B" . "$,44x4~(B"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
242 "Kannada characters to glyphs conversion table.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
243 Default value contains only the basic rules.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
244
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
245 (defvar knd-char-glyph-hash
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
246 (let* ((hash (make-hash-table :test 'equal)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
247 (mapc (function (lambda (x) (puthash (car x) (cdr x) hash)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
248 knd-char-glyph)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
249 hash))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
250
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
251 (defvar knd-char-glyph-regexp
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
252 (kannada-regexp-of-hashtbl-keys knd-char-glyph-hash))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
253
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
254 (defvar knd-conjunct-glyph
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
255 '(("$,1>u(B" . "$,43Q(B") ("$,1>v(B" . "$,43U(B") ("$,1>w(B" . "$,43X(B") ("$,1>x(B" . "$,43[(B") ("$,1>y(B" . "$,43](B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
256 ("$,1>z(B" . "$,43`(B") ("$,1>{(B" . "$,43c(B") ("$,1>|(B" . "$,43g(B") ("$,1>}(B" . "$,43i(B") ("$,1>~(B" . "$,43k(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
257 ("$,1>(B" . "$,43o(B") ("$,1? (B" . "$,43r(B") ("$,1?!(B" . "$,43u(B") ("$,1?"(B" . "$,43x(B") ("$,1?#(B" . "$,43|(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
258 ("$,1?$(B" . "$,44A(B") ("$,1?%(B" . "$,44D(B") ("$,1?&(B" . "$,44G(B") ("$,1?'(B" . "$,44J(B") ("$,1?((B" . "$,44M(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
259 ("$,1?*(B" . "$,44P(B") ("$,1?+(B" . "$,44U(B") ("$,1?,(B" . "$,44Y(B") ("$,1?-(B" . "$,44\(B") ("$,1?.(B" . "$,44](B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
260 ("$,1?/(B" . "$,44`(B") ("$,1?0(B" . "$,44c(B") ("$,1?2(B" . "$,44g(B") ("$,1?3(B" . "$,44y(B") ("$,1?5(B" . "$,44j(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
261 ("$,1?6(B" . "$,44m(B") ("$,1?7(B" . "$,44p(B") ("$,1?8(B" . "$,44s(B") ("$,1?9(B" . "$,44v(B"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
262 "Kannada characters to conjunct glyphs conversion table.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
263
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
264 (defvar knd-conjunct-glyph-hash
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
265 (let* ((hash (make-hash-table :test 'equal)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
266 (mapc (function (lambda (x) (puthash (car x) (cdr x) hash)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
267 knd-conjunct-glyph)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
268 hash))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
269
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
270 (defvar knd-conjunct-glyph-regexp
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
271 (kannada-regexp-of-hashtbl-vals knd-conjunct-glyph-hash))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
272
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
273 (mapc
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
274 (function (lambda (x)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
275 (put-char-code-property (aref (cdr x) 0) 'reference-point '(5 . 3))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
276 knd-conjunct-glyph)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
277
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
278 ;; glyph-to-glyph conversion table.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
279 ;; it is supposed that glyphs are ordered in
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
280 ;; [consonant/nukta] - [matra/virama] - [preceding-r] - [anuswar].
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
281
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
282 (defvar knd-glyph-glyph
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
283 '(("$,45$4A(B" . "$,45*(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
284 ("$,45'4A(B" . "$,45+(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
285 ("$,44A3g(B" . "$,45,(B")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
286 ("$,45$3Q(B" . "$,45-(B")))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
287
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
288 (defvar knd-glyph-glyph-hash
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
289 (let* ((hash (make-hash-table :test 'equal)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
290 (mapc (function (lambda (x) (puthash (car x) (cdr x) hash)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
291 knd-glyph-glyph)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
292 hash))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
293 (defvar knd-glyph-glyph-regexp
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
294 (kannada-regexp-of-hashtbl-keys knd-glyph-glyph-hash))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
295
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
296 (defun knd-charseq (from &optional to)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
297 (if (null to) (setq to from))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
298 (number-sequence (decode-char 'kannada-cdac from)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
299 (decode-char 'kannada-cdac to)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
300
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
301 (defvar knd-glyph-cv
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
302 (append
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
303 (knd-charseq #x40 #x50)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
304 (knd-charseq #x52 #x54)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
305 (knd-charseq #x56 #x57)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
306 (knd-charseq #x59 #x5a)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
307 (knd-charseq #x5c)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
308 (knd-charseq #x5e #x5f)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
309 (knd-charseq #x61 #x62)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
310 (knd-charseq #x64 #x66)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
311 (knd-charseq #x6a)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
312 (knd-charseq #x6c #x6e)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
313 (knd-charseq #x70 #x71)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
314 (knd-charseq #x73 #x74)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
315 (knd-charseq #x76 #x77)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
316 (knd-charseq #x79 #x7b)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
317 (knd-charseq #x7d #x7e)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
318 (knd-charseq #xa2 #xa3)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
319 (knd-charseq #xa5 #xa6)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
320 (knd-charseq #xa8 #xa9)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
321 (knd-charseq #xab #xac)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
322 (knd-charseq #xae #xaf)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
323 (knd-charseq #xb1 #xb2)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
324 (knd-charseq #xb6 #xb8)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
325 (knd-charseq #xb6 #xb8)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
326 (knd-charseq #xba #xbb)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
327 (knd-charseq #xbe #xbf)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
328 (knd-charseq #xc1 #xc2)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
329 (knd-charseq #xc4 #xc6)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
330 (knd-charseq #xc8 #xc9)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
331 (knd-charseq #xcb #xcc)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
332 (knd-charseq #xce #xcf)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
333 (knd-charseq #xd1 #xd2)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
334 (knd-charseq #xd4 #xd5)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
335 (knd-charseq #xd7 #xd8)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
336 (knd-charseq #xc3))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
337 "Kannada Consonants/Vowels/Nukta Glyphs")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
338
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
339 (defvar knd-glyph-space
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
340 (knd-charseq #xb3 #xb4)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
341 "Kannada Spacing Glyphs")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
342
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
343 (defvar knd-glyph-right-modifier
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
344 (append
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
345 (knd-charseq #xdb #xdd)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
346 (knd-charseq #xdf)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
347 (knd-charseq #xe0 #xe3)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
348 (knd-charseq #xe9))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
349 "Kannada Modifiers attached at the right side.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
350
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
351 (defvar knd-glyph-right-modifier-regexp
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
352 (concat "[" knd-glyph-right-modifier "]"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
353
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
354 (defvar knd-glyph-jha-tail
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
355 (knd-charseq #x68)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
356 "Kannada tail for jha.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
357
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
358 (defvar knd-glyph-top-matra
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
359 (append
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
360 (knd-charseq #xda)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
361 (knd-charseq #xdd)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
362 (knd-charseq #xe6)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
363 (knd-charseq #xe8))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
364 "Kannada Matras attached at the top side.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
365
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
366 (defvar knd-glyph-bottom-matra
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
367 (append
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
368 (knd-charseq #xe4 #xe5)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
369 (knd-charseq #xe7))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
370 "Kannada Matras attached at the bottom.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
371
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
372 (defvar knd-glyph-end-marks
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
373 (append
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
374 (knd-charseq #x25)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
375 (knd-charseq #x4d #x4e)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
376 (knd-charseq #xde))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
377 "Kannada end marks: arkavattu, virama, au and diirghaa.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
378
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
379 (defvar knd-glyph-bottom-modifier
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
380 (append
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
381 (knd-charseq #x51)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
382 (knd-charseq #x55)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
383 (knd-charseq #x58)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
384 (knd-charseq #x5b)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
385 (knd-charseq #x5d)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
386 (knd-charseq #x60)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
387 (knd-charseq #x63)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
388 (knd-charseq #x67)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
389 (knd-charseq #x69)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
390 (knd-charseq #x6b)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
391 (knd-charseq #x6f)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
392 (knd-charseq #x72)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
393 (knd-charseq #x75)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
394 (knd-charseq #x78)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
395 (knd-charseq #x7c)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
396 (knd-charseq #xa1)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
397 (knd-charseq #xa4)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
398 (knd-charseq #xa7)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
399 (knd-charseq #xaa)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
400 (knd-charseq #xad)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
401 (knd-charseq #xb0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
402 (knd-charseq #xb5)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
403 (knd-charseq #xb9)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
404 (knd-charseq #xbc #xbd)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
405 (knd-charseq #xc0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
406 (knd-charseq #xc3)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
407 (knd-charseq #xc7)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
408 (knd-charseq #xca)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
409 (knd-charseq #xcd)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
410 (knd-charseq #xd0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
411 (knd-charseq #xd3)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
412 (knd-charseq #xd6)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
413 (knd-charseq #xd9)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
414 (knd-charseq #xea #xef))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
415 "Kannada Modifiers attached at the bottom.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
416
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
417 (defvar knd-glyph-order
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
418 `((,knd-glyph-cv . 1)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
419 (,knd-glyph-top-matra . 2)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
420 (,knd-glyph-jha-tail . 3)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
421 (,knd-glyph-right-modifier . 4)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
422 (,knd-glyph-space . 5)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
423 (,knd-glyph-bottom-modifier . 5)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
424 (,knd-glyph-bottom-matra . 6)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
425 (,knd-glyph-end-marks . 7)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
426 ))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
427
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
428 (mapc
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
429 (function (lambda (x)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
430 (mapc
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
431 (function (lambda (y)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
432 (put-char-code-property y 'composition-order (cdr x))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
433 (car x))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
434 knd-glyph-order)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
435
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
436 (defun kannada-compose-syllable-string (string)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
437 (with-temp-buffer
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
438 (insert (decompose-string string))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
439 (kannada-compose-syllable-region (point-min) (point-max))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
440 (buffer-string)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
441
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
442 ;; kch
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
443 (defun kannada-compose-syllable-region (from to)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
444 "Compose kannada syllable in region FROM to TO."
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
445 (let ((glyph-str nil) (cons-num 0) (glyph-str-list nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
446 (last-virama nil) (preceding-r nil) (last-modifier nil)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
447 (last-char (char-before to)) match-str pos
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
448 glyph-block split-pos (conj nil) (rest nil))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
449 (save-excursion
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
450 (save-restriction
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
451 ;;; *** char-to-glyph conversion ***
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
452 ;; Special rule 1. -- Last virama must be preserved.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
453 (if (eq last-char ?$,1?M(B)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
454 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
455 (setq last-virama t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
456 (narrow-to-region from (1- to)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
457 (narrow-to-region from to))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
458 (goto-char (point-min))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
459 ;; Special rule 2. -- preceding "r virama" must be modifier.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
460 (when (looking-at "$,1?0?M(B.")
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
461 (setq preceding-r t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
462 (goto-char (+ 2 (point))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
463 ;; remove conjunct consonants
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
464 (while (re-search-forward knd-char-glyph-regexp nil t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
465 (setq match-str (match-string 0))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
466 (if (and (string-match kannada-consonant match-str)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
467 (> cons-num 0))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
468 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
469 (setq conj (concat conj (gethash (match-string 0 match-str)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
470 knd-conjunct-glyph-hash)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
471 (setq match-str (replace-match "" t nil match-str))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
472 (if (string-match "$,1?M(B" rest)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
473 (setq rest (replace-match "" t nil rest)))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
474 (setq rest (concat rest match-str))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
475 ;; count the number of consonant-glyhs.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
476 (if (string-match kannada-consonant match-str)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
477 (setq cons-num (1+ cons-num))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
478 ;; translate the rest characters into glyphs
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
479 (setq pos 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
480 (while (string-match knd-char-glyph-regexp rest pos)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
481 (setq match-str (match-string 0 rest))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
482 (setq pos (match-end 0))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
483 (setq glyph-str
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
484 (concat glyph-str (gethash match-str knd-char-glyph-hash))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
485
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
486 (if conj (setq glyph-str (concat glyph-str conj)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
487 (if last-virama (setq glyph-str (concat glyph-str "$,45)(B"))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
488 (goto-char (point-min))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
489 (if (re-search-forward kannada-consonant-needs-twirl nil t)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
490 (progn
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
491 (setq match-str (match-string 0))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
492 (setq glyph-str (concat glyph-str "$,44z(B")))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
493 ;; preceding-r must be attached
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
494 (if preceding-r
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
495 (setq glyph-str (concat glyph-str "$,43%(B")))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
496 ;;; *** glyph-to-glyph conversion ***
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
497 (when (string-match knd-glyph-glyph-regexp glyph-str)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
498 (setq glyph-str
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
499 (replace-match (gethash (match-string 0 glyph-str)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
500 knd-glyph-glyph-hash)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
501 nil t glyph-str)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
502 ;;; *** glyph reordering ***
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
503 (while (setq split-pos (string-match "$,45)(B\\|.$" glyph-str))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
504 (setq glyph-block (substring glyph-str 0 (1+ split-pos)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
505 (setq glyph-str (substring glyph-str (1+ split-pos)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
506 (setq
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
507 glyph-block
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
508 (sort (string-to-list glyph-block)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
509 (function (lambda (x y)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
510 (< (get-char-code-property x 'composition-order)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
511 (get-char-code-property y 'composition-order))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
512 (setq glyph-str-list (nconc glyph-str-list glyph-block)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
513 ;;; *** insert space glyphs for kerning ***
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
514 (if (> cons-num 0)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
515 (let ((curr glyph-str-list) (prev nil) (last-bott nil) bott co)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
516 (while curr
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
517 (setq co (get-char-code-property
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
518 (car curr) 'composition-order)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
519 bott (or (eq co 5) (eq co 6)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
520 (if (and bott last-bott)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
521 (setcdr prev (cons ?$,44T(B curr)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
522 (setq last-bott bott prev curr curr (cdr curr)))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
523 ;; concatenate and attach reference-points.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
524 (setq glyph-str
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
525 (cdr
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
526 (apply
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
527 'nconc
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
528 (mapcar
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
529 (function (lambda (x)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
530 (list
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
531 (or (get-char-code-property x 'reference-point)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
532 '(5 . 3) ;; default reference point.
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
533 )
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
534 x)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
535 glyph-str-list))))))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
536 (compose-region from to glyph-str)))
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
537
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
538 (provide 'knd-util)
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
539
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
540 ;;; arch-tag: 78d32230-a960-46a5-b622-61ed6ffcf8fc
68c22ea6027c Sync to HEAD
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
541 ;;; knd-util.el ends here