2 *******************************************************************************
3 * Copyright (C) 2000-2004, International Business Machines Corporation and *
4 * others. All Rights Reserved. *
5 *******************************************************************************
8 package com.ibm.icu.dev.tool.ime.indic;
10 import java.util.Locale;
12 public class DevanagariInputMethodDescriptor extends IndicIMDescriptor
14 private static final Locale DEVANAGARI = new Locale("hi", "IN");
16 public DevanagariInputMethodDescriptor() {
17 super(DEVANAGARI, "Devanagari");
20 private static char[] keyboardMap;
21 private static char[][] substitutionTable;
22 private static char[] joinWithNukta;
23 private static char[] nuktaForm;
25 protected IndicInputMethodImpl getImpl() {
26 if (keyboardMap == null) {
27 keyboardMap = new char[] {
61 /* 21 */ '\u090D', // '!'
62 /* 22 */ '\u0920', // '"'
63 /* 23 */ '\uFF00', // '#'
64 /* 24 */ '\uFF01', // '$'
65 /* 25 */ '\uFF02', // '%'
66 /* 26 */ '\uFF04', // '&'
67 /* 27 */ '\u091F', // '''
68 /* 28 */ '\u0028', // '('
69 /* 29 */ '\u0029', // ')'
70 /* 2A */ '\uFF05', // '*'
71 /* 2B */ '\u090B', // '+'
72 /* 2C */ '\u002C', // ','
73 /* 2D */ '\u002D', // '-'
74 /* 2E */ '\u002E', // '.'
75 /* 2F */ '\u092F', // '/'
76 /* 30 */ '\u0966', // '0'
77 /* 31 */ '\u0967', // '1'
78 /* 32 */ '\u0968', // '2'
79 /* 33 */ '\u0969', // '3'
80 /* 34 */ '\u096A', // '4'
81 /* 35 */ '\u096B', // '5'
82 /* 36 */ '\u096C', // '6'
83 /* 37 */ '\u096D', // '7'
84 /* 38 */ '\u096E', // '8'
85 /* 39 */ '\u096F', // '9'
86 /* 3A */ '\u091B', // ':'
87 /* 3B */ '\u091A', // ';'
88 /* 3C */ '\u0937', // '<'
89 /* 3D */ '\u0943', // '='
90 /* 3E */ '\u0964', // '>'
91 /* 3F */ '\u095F', // '?'
92 /* 40 */ '\u0945', // '@'
93 /* 41 */ '\u0913', // 'A'
94 /* 42 */ '\u0934', // 'B'
95 /* 43 */ '\u0923', // 'C'
96 /* 44 */ '\u0905', // 'D'
97 /* 45 */ '\u0906', // 'E'
98 /* 46 */ '\u0907', // 'F'
99 /* 47 */ '\u0909', // 'G'
100 /* 48 */ '\u092B', // 'H'
101 /* 49 */ '\u0918', // 'I'
102 /* 4A */ '\u0931', // 'J'
103 /* 4B */ '\u0916', // 'K'
104 /* 4C */ '\u0925', // 'L'
105 /* 4D */ '\u0936', // 'M'
106 /* 4E */ '\u0933', // 'N'
107 /* 4F */ '\u0927', // 'O'
108 /* 50 */ '\u091D', // 'P'
109 /* 51 */ '\u0914', // 'Q'
110 /* 52 */ '\u0908', // 'R'
111 /* 53 */ '\u090F', // 'S'
112 /* 54 */ '\u090A', // 'T'
113 /* 55 */ '\u0919', // 'U'
114 /* 56 */ '\u0929', // 'V'
115 /* 57 */ '\u0910', // 'W'
116 /* 58 */ '\u0901', // 'X'
117 /* 59 */ '\u092D', // 'Y'
118 /* 5A */ '\u090E', // 'Z'
119 /* 5B */ '\u0921', // '['
120 /* 5C */ '\u0949', // '\'
121 /* 5D */ '\u093C', // ']'
122 /* 5E */ '\uFF03', // '^'
123 /* 5F */ '\u0903', // '_'
124 /* 60 */ '\u094A', // '`'
125 /* 61 */ '\u094B', // 'a'
126 /* 62 */ '\u0935', // 'b'
127 /* 63 */ '\u092E', // 'c'
128 /* 64 */ '\u094D', // 'd'
129 /* 65 */ '\u093E', // 'e'
130 /* 66 */ '\u093F', // 'f'
131 /* 67 */ '\u0941', // 'g'
132 /* 68 */ '\u092A', // 'h'
133 /* 69 */ '\u0917', // 'i'
134 /* 6A */ '\u0930', // 'j'
135 /* 6B */ '\u0915', // 'k'
136 /* 6C */ '\u0924', // 'l'
137 /* 6D */ '\u0938', // 'm'
138 /* 6E */ '\u0932', // 'n'
139 /* 6F */ '\u0926', // 'o'
140 /* 70 */ '\u091C', // 'p'
141 /* 71 */ '\u094C', // 'q'
142 /* 72 */ '\u0940', // 'r'
143 /* 73 */ '\u0947', // 's'
144 /* 74 */ '\u0942', // 't'
145 /* 75 */ '\u0939', // 'u'
146 /* 76 */ '\u0928', // 'v'
147 /* 77 */ '\u0948', // 'w'
148 /* 78 */ '\u0902', // 'x'
149 /* 79 */ '\u092C', // 'y'
150 /* 7A */ '\u0946', // 'z'
151 /* 7B */ '\u0922', // '{'
152 /* 7C */ '\u0911', // '|'
153 /* 7D */ '\u091E', // '}'
154 /* 7E */ '\u0912', // '~'
155 /* 7F */ '\u007F' // '
\7f'
158 // the character substitutions for the meta characters.
159 char[] RA_SUB = {'\u094D', '\u0930'};
160 char[] RA_SUP = {'\u0930', '\u094D'};
161 char[] CONJ_JA_NYA = {'\u091C', '\u094D', '\u091E'};
162 char[] CONJ_TA_RA = {'\u0924', '\u094D', '\u0930'};
163 char[] CONJ_KA_SSA = {'\u0915', '\u094D', '\u0937'};
164 char[] CONJ_SHA_RA = {'\u0936', '\u094D', '\u0930'};
166 substitutionTable = new char[][] {
167 RA_SUB, RA_SUP, CONJ_JA_NYA, CONJ_TA_RA, CONJ_KA_SSA, CONJ_SHA_RA
170 // The following characters followed by Nukta should be replaced
171 // by the corresponding character as defined in ISCII91
172 char SIGN_CANDRABINDU = '\u0901';
173 char LETTER_I = '\u0907';
174 char LETTER_II = '\u0908';
175 char LETTER_VOCALIC_R = '\u090B';
176 char LETTER_KA = '\u0915';
177 char LETTER_KHA = '\u0916';
178 char LETTER_GA = '\u0917';
179 char LETTER_JA = '\u091C';
180 char LETTER_DDA = '\u0921';
181 char LETTER_DDHA = '\u0922';
182 char LETTER_PHA = '\u092B';
183 char VOWEL_SIGN_I = '\u093F';
184 char VOWEL_SIGN_II = '\u0940';
185 char VOWEL_SIGN_VOCALIC_R = '\u0943';
186 char DANDA = '\u0964';
188 // The following characters replace the above characters followed by Nukta. These
189 // are defined in one to one correspondence order.
190 char SIGN_OM = '\u0950';
191 char LETTER_VOCALIC_L = '\u090C';
192 char LETTER_VOCALIC_LL = '\u0961';
193 char LETTER_VOCALIC_RR = '\u0960';
194 char LETTER_QA = '\u0958';
195 char LETTER_KHHA = '\u0959';
196 char LETTER_GHHA = '\u095A';
197 char LETTER_ZA = '\u095B';
198 char LETTER_DDDHA = '\u095C';
199 char LETTER_RHA = '\u095D';
200 char LETTER_FA = '\u095E';
201 char VOWEL_SIGN_VOCALIC_L = '\u0962';
202 char VOWEL_SIGN_VOCALIC_LL = '\u0963';
203 char VOWEL_SIGN_VOCALIC_RR = '\u0944';
204 char SIGN_AVAGRAHA = '\u093D';
206 joinWithNukta = new char[] {
220 VOWEL_SIGN_VOCALIC_R,
224 nuktaForm = new char[] {
236 VOWEL_SIGN_VOCALIC_L,
237 VOWEL_SIGN_VOCALIC_LL,
238 VOWEL_SIGN_VOCALIC_RR,
243 return new IndicInputMethodImpl(keyboardMap, joinWithNukta, nuktaForm, substitutionTable);