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 GurmukhiInputMethodDescriptor extends IndicIMDescriptor
14 private static final Locale GURMUKHI = new Locale("pa", "IN"); // pa = Punjabi
16 public GurmukhiInputMethodDescriptor() {
17 super(GURMUKHI, "Gurmukhi");
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 */ '\u0A0D', // '!'
62 /* 22 */ '\u0A20', // '"'
63 /* 23 */ '\uFF00', // '#'
64 /* 24 */ '\uFFFF', // '$'
65 /* 25 */ '\uFFFF', // '%'
66 /* 26 */ '\uFFFF', // '&'
67 /* 27 */ '\u0A1F', // '''
68 /* 28 */ '\u0028', // '('
69 /* 29 */ '\u0029', // ')'
70 /* 2A */ '\uFFFF', // '*'
71 /* 2B */ '\u0A0B', // '+'
72 /* 2C */ '\u002C', // ','
73 /* 2D */ '\u002D', // '-'
74 /* 2E */ '\u002E', // '.'
75 /* 2F */ '\u0A2F', // '/'
76 /* 30 */ '\u0A66', // '0'
77 /* 31 */ '\u0A67', // '1'
78 /* 32 */ '\u0A68', // '2'
79 /* 33 */ '\u0A69', // '3'
80 /* 34 */ '\u0A6A', // '4'
81 /* 35 */ '\u0A6B', // '5'
82 /* 36 */ '\u0A6C', // '6'
83 /* 37 */ '\u0A6D', // '7'
84 /* 38 */ '\u0A6E', // '8'
85 /* 39 */ '\u0A6F', // '9'
86 /* 3A */ '\u0A1B', // ':'
87 /* 3B */ '\u0A1A', // ';'
88 /* 3C */ '\u0A37', // '<'
89 /* 3D */ '\u0A43', // '='
90 /* 3E */ '\u0964', // '>' (Devanagari danda)
91 /* 3F */ '\u0A5F', // '?'
92 /* 40 */ '\u0A45', // '@'
93 /* 41 */ '\u0A13', // 'A'
94 /* 42 */ '\u0A34', // 'B'
95 /* 43 */ '\u0A23', // 'C'
96 /* 44 */ '\u0A05', // 'D'
97 /* 45 */ '\u0A06', // 'E'
98 /* 46 */ '\u0A07', // 'F'
99 /* 47 */ '\u0A09', // 'G'
100 /* 48 */ '\u0A2B', // 'H'
101 /* 49 */ '\u0A18', // 'I'
102 /* 4A */ '\u0A31', // 'J'
103 /* 4B */ '\u0A16', // 'K'
104 /* 4C */ '\u0A25', // 'L'
105 /* 4D */ '\u0A36', // 'M'
106 /* 4E */ '\u0A33', // 'N'
107 /* 4F */ '\u0A27', // 'O'
108 /* 50 */ '\u0A1D', // 'P'
109 /* 51 */ '\u0A14', // 'Q'
110 /* 52 */ '\u0A08', // 'R'
111 /* 53 */ '\u0A0F', // 'S'
112 /* 54 */ '\u0A0A', // 'T'
113 /* 55 */ '\u0A19', // 'U'
114 /* 56 */ '\u0A29', // 'V'
115 /* 57 */ '\u0A10', // 'W'
116 /* 58 */ '\u0A01', // 'X'
117 /* 59 */ '\u0A2D', // 'Y'
118 /* 5A */ '\u0A0E', // 'Z'
119 /* 5B */ '\u0A21', // '['
120 /* 5C */ '\u0A49', // '\'
121 /* 5D */ '\u0A3C', // ']'
122 /* 5E */ '\uFFFF', // '^'
123 /* 5F */ '\u0A03', // '_'
124 /* 60 */ '\u0A4A', // '`'
125 /* 61 */ '\u0A4B', // 'a'
126 /* 62 */ '\u0A35', // 'b'
127 /* 63 */ '\u0A2E', // 'c'
128 /* 64 */ '\u0A4D', // 'd'
129 /* 65 */ '\u0A3E', // 'e'
130 /* 66 */ '\u0A3F', // 'f'
131 /* 67 */ '\u0A41', // 'g'
132 /* 68 */ '\u0A2A', // 'h'
133 /* 69 */ '\u0A17', // 'i'
134 /* 6A */ '\u0A30', // 'j'
135 /* 6B */ '\u0A15', // 'k'
136 /* 6C */ '\u0A24', // 'l'
137 /* 6D */ '\u0A38', // 'm'
138 /* 6E */ '\u0A32', // 'n'
139 /* 6F */ '\u0A26', // 'o'
140 /* 70 */ '\u0A1C', // 'p'
141 /* 71 */ '\u0A4C', // 'q'
142 /* 72 */ '\u0A40', // 'r'
143 /* 73 */ '\u0A47', // 's'
144 /* 74 */ '\u0A42', // 't'
145 /* 75 */ '\u0A39', // 'u'
146 /* 76 */ '\u0A28', // 'v'
147 /* 77 */ '\u0A48', // 'w'
148 /* 78 */ '\u0A70', // 'x' (Gurmukhi TIPPI rather than BINDI)
149 /* 79 */ '\u0A2C', // 'y'
150 /* 7A */ '\u0A46', // 'z'
151 /* 7B */ '\u0A22', // '{'
152 /* 7C */ '\u0A11', // '|'
153 /* 7D */ '\u0A1E', // '}'
154 /* 7E */ '\u0A12', // '~'
155 /* 7F */ '\u007F' // '
\7f'
158 char[] RA_SUB = {'\u0A4D', '\u0A30'};
160 substitutionTable = new char[][] {
164 // The following characters followed by Nukta should be replaced
165 // by the corresponding character as defined in ISCII91
166 char LETTER_KHA = '\u0A16';
167 char LETTER_GA = '\u0A17';
168 char LETTER_JA = '\u0A1C';
169 char LETTER_DDA = '\u0A21';
170 char LETTER_PHA = '\u0A2B';
172 // The following characters replace the above characters followed by Nukta. These
173 // are defined in one to one correspondence order.
174 // NOTE: the inscript keyboard doc. lists a KA + NUKTA and a DDHA + NUKTA
175 // neither of which seem to have Unicode code points...
176 char LETTER_KHHA = '\u0A59';
177 char LETTER_GHHA = '\u0A5A';
178 char LETTER_ZA = '\u0A5B';
179 char LETTER_RRA = '\u0A5C';
180 char LETTER_FA = '\u0A5E';
182 joinWithNukta = new char[] {
190 nuktaForm = new char[] {
199 return new IndicInputMethodImpl(keyboardMap, joinWithNukta, nuktaForm, substitutionTable);