blob: 3fbaa1eed98d9121335df3a75a5673378e1e8f0a [file] [log] [blame]
/*
*******************************************************************************
* Copyright (C) 2000-2004, International Business Machines Corporation and *
* others. All Rights Reserved. *
*******************************************************************************
*/
package com.ibm.icu.dev.tool.ime.indic;
import java.util.Locale;
public class OriyaInputMethodDescriptor extends IndicIMDescriptor
{
private static final Locale ORIYA = new Locale("or", "IN");
public OriyaInputMethodDescriptor() {
super(ORIYA, "Oriya");
}
private static char[] keyboardMap;
private static char[][] substitutionTable;
private static char[] joinWithNukta;
private static char[] nuktaForm;
protected IndicInputMethodImpl getImpl() {
if (keyboardMap == null) {
keyboardMap = new char[] {
/* 00 */ '\u0000',
/* 01 */ '\u0001',
/* 02 */ '\u0002',
/* 03 */ '\u0003',
/* 04 */ '\u0004',
/* 05 */ '\u0005',
/* 06 */ '\u0006',
/* 07 */ '\u0007',
/* 08 */ '\u0008',
/* 09 */ '\u0009',
/* 0A */ '\012',
/* 0B */ '\u000B',
/* 0C */ '\u000C',
/* 0D */ '\015',
/* 0E */ '\u000E',
/* 0F */ '\u000F',
/* 10 */ '\u0010',
/* 11 */ '\u0011',
/* 12 */ '\u0012',
/* 13 */ '\u0013',
/* 14 */ '\u0014',
/* 15 */ '\u0015',
/* 16 */ '\u0016',
/* 17 */ '\u0017',
/* 18 */ '\u0018',
/* 19 */ '\u0019',
/* 1A */ '\u001A',
/* 1B */ '\u001B',
/* 1C */ '\u001C',
/* 1D */ '\u001D',
/* 1E */ '\u001E',
/* 1F */ '\u001F',
/* 20 */ '\u0020',
/* 21 */ '\uFFFF', // '!'
/* 22 */ '\u0B20', // '"'
/* 23 */ '\uFF00', // '#'
/* 24 */ '\uFF01', // '$'
/* 25 */ '\uFF02', // '%'
/* 26 */ '\uFF04', // '&'
/* 27 */ '\u0B1F', // '''
/* 28 */ '\u0028', // '('
/* 29 */ '\u0029', // ')'
/* 2A */ '\uFF05', // '*'
/* 2B */ '\u0B0B', // '+'
/* 2C */ '\u002C', // ','
/* 2D */ '\u002D', // '-'
/* 2E */ '\u002E', // '.'
/* 2F */ '\u0B5F', // '/'
/* 30 */ '\u0B66', // '0'
/* 31 */ '\u0B67', // '1'
/* 32 */ '\u0B68', // '2'
/* 33 */ '\u0B69', // '3'
/* 34 */ '\u0B6A', // '4'
/* 35 */ '\u0B6B', // '5'
/* 36 */ '\u0B6C', // '6'
/* 37 */ '\u0B6D', // '7'
/* 38 */ '\u0B6E', // '8'
/* 39 */ '\u0B6F', // '9'
/* 3A */ '\u0B1B', // ':'
/* 3B */ '\u0B1A', // ';'
/* 3C */ '\u0B37', // '<'
/* 3D */ '\u0B43', // '='
/* 3E */ '\u0964', // '>' (Devanagari danda)
/* 3F */ '\u0B2F', // '?'
/* 40 */ '\uFFFF', // '@'
/* 41 */ '\u0B13', // 'A'
/* 42 */ '\uFFFF', // 'B'
/* 43 */ '\u0B23', // 'C'
/* 44 */ '\u0B05', // 'D'
/* 45 */ '\u0B06', // 'E'
/* 46 */ '\u0B07', // 'F'
/* 47 */ '\u0B09', // 'G'
/* 48 */ '\u0B2B', // 'H'
/* 49 */ '\u0B18', // 'I'
/* 4A */ '\uFFFF', // 'J'
/* 4B */ '\u0B16', // 'K'
/* 4C */ '\u0B25', // 'L'
/* 4D */ '\u0B36', // 'M'
/* 4E */ '\u0B33', // 'N'
/* 4F */ '\u0B27', // 'O'
/* 50 */ '\u0B1D', // 'P'
/* 51 */ '\u0B14', // 'Q'
/* 52 */ '\u0B08', // 'R'
/* 53 */ '\u0B0F', // 'S'
/* 54 */ '\u0B0A', // 'T'
/* 55 */ '\u0B19', // 'U'
/* 56 */ '\uFFFF', // 'V'
/* 57 */ '\u0B10', // 'W'
/* 58 */ '\u0B01', // 'X'
/* 59 */ '\u0B2D', // 'Y'
/* 5A */ '\uFFFF', // 'Z'
/* 5B */ '\u0B21', // '['
/* 5C */ '\uFFFF', // '\'
/* 5D */ '\u0B3C', // ']'
/* 5E */ '\uFF03', // '^'
/* 5F */ '\u0B03', // '_'
/* 60 */ '\uFFFF', // '`'
/* 61 */ '\u0B4B', // 'a'
/* 62 */ '\u0B2C', // 'b' (va, but no Unicode code point, used ba instead)
/* 63 */ '\u0B2E', // 'c'
/* 64 */ '\u0B4D', // 'd'
/* 65 */ '\u0B3E', // 'e'
/* 66 */ '\u0B3F', // 'f'
/* 67 */ '\u0B41', // 'g'
/* 68 */ '\u0B2A', // 'h'
/* 69 */ '\u0B17', // 'i'
/* 6A */ '\u0B30', // 'j'
/* 6B */ '\u0B15', // 'k'
/* 6C */ '\u0B24', // 'l'
/* 6D */ '\u0B38', // 'm'
/* 6E */ '\u0B32', // 'n'
/* 6F */ '\u0B26', // 'o'
/* 70 */ '\u0B1C', // 'p'
/* 71 */ '\u0B4C', // 'q'
/* 72 */ '\u0B40', // 'r'
/* 73 */ '\u0B47', // 's'
/* 74 */ '\u0B42', // 't'
/* 75 */ '\u0B39', // 'u'
/* 76 */ '\u0B28', // 'v'
/* 77 */ '\u0B48', // 'w'
/* 78 */ '\u0B02', // 'x'
/* 79 */ '\u0B2C', // 'y'
/* 7A */ '\uFFFF', // 'z'
/* 7B */ '\u0B22', // '{'
/* 7C */ '\uFFFF', // '|'
/* 7D */ '\u0B1E', // '}'
/* 7E */ '\uFFFF', // '~'
/* 7F */ '\u007F' // ''
};
char[] RA_SUB = {'\u0B4D', '\u0B30'};
char[] RA_SUP = {'\u0B30', '\u0B4D'};
char[] CONJ_JA_NYA = {'\u0B1C', '\u0B4D', '\u0B1E'};
char[] CONJ_TA_RA = {'\u0B24', '\u0B4D', '\u0B30'};
char[] CONJ_KA_SSA = {'\u0B15', '\u0B4D', '\u0B37'};
char[] CONJ_SHA_RA = {'\u0B36', '\u0B4D', '\u0B30'};
substitutionTable = new char[][] {
RA_SUB, RA_SUP, CONJ_JA_NYA, CONJ_TA_RA, CONJ_KA_SSA, CONJ_SHA_RA
};
// The following characters followed by Nukta should be replaced
// by the corresponding character as defined in ISCII91
char LETTER_I = '\u0B07';
char LETTER_II = '\u0B08';
char LETTER_VOCALIC_R = '\u0B0B';
char LETTER_DDA = '\u0B21';
char LETTER_DDHA = '\u0B22';
char VOWEL_SIGN_I = '\u0B3F';
char VOWEL_SIGN_II = '\u0B40';
// The following characters replace the above characters followed by Nukta. These
// are defined in one to one correspondence order.
char LETTER_VOCALIC_L = '\u0B0C';
char LETTER_VOCALIC_LL = '\u0B61';
char LETTER_VOCALIC_RR = '\u0B60';
char LETTER_RRA = '\u0B5C';
char LETTER_RHA = '\u0B5D';
char VOWEL_SIGN_VOCALIC_L = '\u0B62';
char VOWEL_SIGN_VOCALIC_LL = '\u0B63';
joinWithNukta = new char[] {
LETTER_VOCALIC_R ,
LETTER_I,
LETTER_II,
LETTER_DDA,
LETTER_DDHA,
VOWEL_SIGN_I,
VOWEL_SIGN_II
};
nuktaForm = new char[] {
LETTER_VOCALIC_RR,
LETTER_VOCALIC_L,
LETTER_VOCALIC_LL,
LETTER_RRA,
LETTER_RHA,
VOWEL_SIGN_VOCALIC_L,
VOWEL_SIGN_VOCALIC_LL
};
}
return new IndicInputMethodImpl(keyboardMap, joinWithNukta, nuktaForm, substitutionTable);
}
}