mirror of
https://github.com/Julow/Unexpected-Keyboard.git
synced 2025-01-16 10:28:20 +01:00
Move diacritics mapping to the compose state machine
This replaces the switch cases in KeyModifier.java with JSON files, one for each diacritic. The number of states increases from 6727 to 7377. The apk size slightly decreases (around 3kb).
This commit is contained in:
parent
ecac6a77f8
commit
91ace060bc
25
srcs/compose/accent_aigu.json
Normal file
25
srcs/compose/accent_aigu.json
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
{
|
||||||
|
"a": "á",
|
||||||
|
"c": "ć",
|
||||||
|
"e": "é",
|
||||||
|
"i": "í",
|
||||||
|
"l": "ĺ",
|
||||||
|
"ń": "ń",
|
||||||
|
"o": "ó",
|
||||||
|
"r": "ŕ",
|
||||||
|
"s": "ś",
|
||||||
|
"u": "ú",
|
||||||
|
"y": "ý",
|
||||||
|
"z": "ź",
|
||||||
|
"ü": "ǘ",
|
||||||
|
"j": "j\u0301",
|
||||||
|
"у": "у\u0301",
|
||||||
|
"е": "е\u0301",
|
||||||
|
"а": "а\u0301",
|
||||||
|
"о": "о\u0301",
|
||||||
|
"и": "и\u0301",
|
||||||
|
"ы": "ы\u0301",
|
||||||
|
"э": "э\u0301",
|
||||||
|
"ю": "ю\u0301",
|
||||||
|
"я": "я\u0301"
|
||||||
|
}
|
13
srcs/compose/accent_arrows.json
Normal file
13
srcs/compose/accent_arrows.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"0": "↔",
|
||||||
|
"1": "↙",
|
||||||
|
"2": "↓",
|
||||||
|
"3": "↘",
|
||||||
|
"4": "←",
|
||||||
|
"5": "↕",
|
||||||
|
"6": "→",
|
||||||
|
"7": "↖",
|
||||||
|
"8": "↑",
|
||||||
|
"9": "↗",
|
||||||
|
".": "↵"
|
||||||
|
}
|
18
srcs/compose/accent_bar.json
Normal file
18
srcs/compose/accent_bar.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"b": "ƀ",
|
||||||
|
"c": "ꞓ",
|
||||||
|
"d": "đ",
|
||||||
|
"g": "ǥ",
|
||||||
|
"i": "ɨ",
|
||||||
|
"j": "ɉ",
|
||||||
|
"k": "ꝁ",
|
||||||
|
"l": "ƚ",
|
||||||
|
"o": "ɵ",
|
||||||
|
"p": "ᵽ",
|
||||||
|
"q": "ꝗ",
|
||||||
|
"r": "ɍ",
|
||||||
|
"t": "ŧ",
|
||||||
|
"u": "ʉ",
|
||||||
|
"y": "ɏ",
|
||||||
|
"z": "ƶ"
|
||||||
|
}
|
13
srcs/compose/accent_box.json
Normal file
13
srcs/compose/accent_box.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"1": "└",
|
||||||
|
"2": "┴",
|
||||||
|
"3": "┘",
|
||||||
|
"4": "├",
|
||||||
|
"5": "┼",
|
||||||
|
"6": "┤",
|
||||||
|
"7": "┌",
|
||||||
|
"8": "┬",
|
||||||
|
"9": "┐",
|
||||||
|
"0": "─",
|
||||||
|
".": "│"
|
||||||
|
}
|
16
srcs/compose/accent_caron.json
Normal file
16
srcs/compose/accent_caron.json
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
{
|
||||||
|
"a": "ǎ",
|
||||||
|
"c": "č",
|
||||||
|
"d": "ď",
|
||||||
|
"e": "ě",
|
||||||
|
"i": "ǐ",
|
||||||
|
"l": "ľ",
|
||||||
|
"n": "ň",
|
||||||
|
"o": "ǒ",
|
||||||
|
"r": "ř",
|
||||||
|
"s": "š",
|
||||||
|
"t": "ť",
|
||||||
|
"u": "ǔ",
|
||||||
|
"z": "ž",
|
||||||
|
"ü": "ǚ"
|
||||||
|
}
|
13
srcs/compose/accent_cedille.json
Normal file
13
srcs/compose/accent_cedille.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"c": "ç",
|
||||||
|
"d": "ḑ",
|
||||||
|
"e": "ȩ",
|
||||||
|
"g": "ģ",
|
||||||
|
"h": "ḩ",
|
||||||
|
"k": "ķ",
|
||||||
|
"l": "ļ",
|
||||||
|
"n": "ņ",
|
||||||
|
"r": "ŗ",
|
||||||
|
"s": "ş",
|
||||||
|
"t": "ţ"
|
||||||
|
}
|
13
srcs/compose/accent_circonflexe.json
Normal file
13
srcs/compose/accent_circonflexe.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"a": "â",
|
||||||
|
"c": "ĉ",
|
||||||
|
"e": "ê",
|
||||||
|
"g": "ĝ",
|
||||||
|
"h": "ĥ",
|
||||||
|
"i": "î",
|
||||||
|
"j": "ĵ",
|
||||||
|
"o": "ô",
|
||||||
|
"ŝ": "ŝ",
|
||||||
|
"u": "û",
|
||||||
|
"z": "ẑ"
|
||||||
|
}
|
21
srcs/compose/accent_dot_above.json
Normal file
21
srcs/compose/accent_dot_above.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"a": "ȧ",
|
||||||
|
"b": "ḃ",
|
||||||
|
"c": "ċ",
|
||||||
|
"d": "ḋ",
|
||||||
|
"e": "ė",
|
||||||
|
"f": "ḟ",
|
||||||
|
"g": "ġ",
|
||||||
|
"h": "ḣ",
|
||||||
|
"m": "ṁ",
|
||||||
|
"n": "ṅ",
|
||||||
|
"o": "ȯ",
|
||||||
|
"p": "ṗ",
|
||||||
|
"r": "ṙ",
|
||||||
|
"s": "ṡ",
|
||||||
|
"t": "ṫ",
|
||||||
|
"w": "ẇ",
|
||||||
|
"x": "ẋ",
|
||||||
|
"y": "ẏ",
|
||||||
|
"z": "ż"
|
||||||
|
}
|
14
srcs/compose/accent_dot_below.json
Normal file
14
srcs/compose/accent_dot_below.json
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"a": "ạ",
|
||||||
|
"ă": "ặ",
|
||||||
|
"â": "ậ",
|
||||||
|
"e": "ẹ",
|
||||||
|
"ê": "ệ",
|
||||||
|
"i": "ị",
|
||||||
|
"o": "ọ",
|
||||||
|
"ô": "ộ",
|
||||||
|
"ơ": "ợ",
|
||||||
|
"u": "ụ",
|
||||||
|
"ư": "ự",
|
||||||
|
"y": "ỵ"
|
||||||
|
}
|
10
srcs/compose/accent_double_aigu.json
Normal file
10
srcs/compose/accent_double_aigu.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"o": "ő",
|
||||||
|
"u": "ű",
|
||||||
|
" ": "˝",
|
||||||
|
"a": "a\u030b",
|
||||||
|
"e": "e\u030b",
|
||||||
|
"i": "i\u030b",
|
||||||
|
"m": "m\u030b",
|
||||||
|
"y": "y\u030b"
|
||||||
|
}
|
8
srcs/compose/accent_grave.json
Normal file
8
srcs/compose/accent_grave.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"a": "à",
|
||||||
|
"e": "è",
|
||||||
|
"i": "ì",
|
||||||
|
"o": "ò",
|
||||||
|
"u": "ù",
|
||||||
|
"ü": "ǜ"
|
||||||
|
}
|
14
srcs/compose/accent_hook_above.json
Normal file
14
srcs/compose/accent_hook_above.json
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"a": "ả",
|
||||||
|
"ă": "ẳ",
|
||||||
|
"â": "ẩ",
|
||||||
|
"e": "ẻ",
|
||||||
|
"ê": "ể",
|
||||||
|
"i": "ỉ",
|
||||||
|
"o": "ỏ",
|
||||||
|
"ô": "ổ",
|
||||||
|
"ơ": "ở",
|
||||||
|
"u": "ủ",
|
||||||
|
"ư": "ử",
|
||||||
|
"y": "ỷ"
|
||||||
|
}
|
14
srcs/compose/accent_horn.json
Normal file
14
srcs/compose/accent_horn.json
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"o": "ơ",
|
||||||
|
"ó": "ớ",
|
||||||
|
"ò": "ờ",
|
||||||
|
"ỏ": "ở",
|
||||||
|
"õ": "ỡ",
|
||||||
|
"ọ": "ợ",
|
||||||
|
"u": "ư",
|
||||||
|
"ú": "ứ",
|
||||||
|
"ù": "ừ",
|
||||||
|
"ủ": "ử",
|
||||||
|
"ũ": "ữ",
|
||||||
|
"ụ": "ự"
|
||||||
|
}
|
8
srcs/compose/accent_macron.json
Normal file
8
srcs/compose/accent_macron.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"a": "ā",
|
||||||
|
"e": "ē",
|
||||||
|
"i": "ī",
|
||||||
|
"o": "ō",
|
||||||
|
"u": "ū",
|
||||||
|
"ü": "ǖ"
|
||||||
|
}
|
10
srcs/compose/accent_ogonek.json
Normal file
10
srcs/compose/accent_ogonek.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"a": "ą",
|
||||||
|
"e": "ę",
|
||||||
|
"i": "į",
|
||||||
|
"k": "ķ",
|
||||||
|
"l": "ļ",
|
||||||
|
"n": "ņ",
|
||||||
|
"o": "ǫ",
|
||||||
|
"u": "ų"
|
||||||
|
}
|
14
srcs/compose/accent_ordinal.json
Normal file
14
srcs/compose/accent_ordinal.json
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"a": "ª",
|
||||||
|
"o": "º",
|
||||||
|
"1": "ª",
|
||||||
|
"2": "º",
|
||||||
|
"3": "ⁿ",
|
||||||
|
"4": "ᵈ",
|
||||||
|
"5": "ᵉ",
|
||||||
|
"6": "ʳ",
|
||||||
|
"7": "ˢ",
|
||||||
|
"8": "ᵗ",
|
||||||
|
"9": "ʰ",
|
||||||
|
"*": "°"
|
||||||
|
}
|
4
srcs/compose/accent_ring.json
Normal file
4
srcs/compose/accent_ring.json
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"a": "å",
|
||||||
|
"u": "ů"
|
||||||
|
}
|
14
srcs/compose/accent_slash.json
Normal file
14
srcs/compose/accent_slash.json
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"a": "ⱥ",
|
||||||
|
"b": "␢",
|
||||||
|
"c": "ȼ",
|
||||||
|
"e": "ɇ",
|
||||||
|
"g": "ꞡ",
|
||||||
|
"k": "ꝃ",
|
||||||
|
"l": "ł",
|
||||||
|
"n": "ꞥ",
|
||||||
|
"o": "ø",
|
||||||
|
"r": "ꞧ",
|
||||||
|
"s": "ꞩ",
|
||||||
|
"t": "ⱦ"
|
||||||
|
}
|
34
srcs/compose/accent_subscript.json
Normal file
34
srcs/compose/accent_subscript.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"1": "₁",
|
||||||
|
"2": "₂",
|
||||||
|
"3": "₃",
|
||||||
|
"4": "₄",
|
||||||
|
"5": "₅",
|
||||||
|
"6": "₆",
|
||||||
|
"7": "₇",
|
||||||
|
"8": "₈",
|
||||||
|
"9": "₉",
|
||||||
|
"0": "₀",
|
||||||
|
"+": "₊",
|
||||||
|
"-": "₋",
|
||||||
|
"=": "₌",
|
||||||
|
"(": "₍",
|
||||||
|
")": "₎",
|
||||||
|
"a": "ₐ",
|
||||||
|
"e": "ₑ",
|
||||||
|
"h": "ₕ",
|
||||||
|
"i": "ᵢ",
|
||||||
|
"j": "ⱼ",
|
||||||
|
"k": "ₖ",
|
||||||
|
"l": "ₗ",
|
||||||
|
"m": "ₘ",
|
||||||
|
"n": "ₙ",
|
||||||
|
"o": "ₒ",
|
||||||
|
"p": "ₚ",
|
||||||
|
"r": "ᵣ",
|
||||||
|
"s": "ₛ",
|
||||||
|
"t": "ₜ",
|
||||||
|
"u": "ᵤ",
|
||||||
|
"v": "ᵥ",
|
||||||
|
"x": "ₓ"
|
||||||
|
}
|
42
srcs/compose/accent_superscript.json
Normal file
42
srcs/compose/accent_superscript.json
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
{
|
||||||
|
"1": "¹",
|
||||||
|
"2": "²",
|
||||||
|
"3": "³",
|
||||||
|
"4": "⁴",
|
||||||
|
"5": "⁵",
|
||||||
|
"6": "⁶",
|
||||||
|
"7": "⁷",
|
||||||
|
"8": "⁸",
|
||||||
|
"9": "⁹",
|
||||||
|
"0": "⁰",
|
||||||
|
"+": "⁺",
|
||||||
|
"-": "⁻",
|
||||||
|
"=": "⁼",
|
||||||
|
"(": "⁽",
|
||||||
|
")": "⁾",
|
||||||
|
"a": "ᵃ",
|
||||||
|
"b": "ᵇ",
|
||||||
|
"c": "ᶜ",
|
||||||
|
"d": "ᵈ",
|
||||||
|
"e": "ᵉ",
|
||||||
|
"f": "ᶠ",
|
||||||
|
"g": "ᵍ",
|
||||||
|
"h": "ʰ",
|
||||||
|
"i": "ⁱ",
|
||||||
|
"j": "ʲ",
|
||||||
|
"k": "ᵏ",
|
||||||
|
"l": "ˡ",
|
||||||
|
"m": "ᵐ",
|
||||||
|
"n": "ⁿ",
|
||||||
|
"o": "ᵒ",
|
||||||
|
"p": "ᵖ",
|
||||||
|
"r": "ʳ",
|
||||||
|
"s": "ˢ",
|
||||||
|
"t": "ᵗ",
|
||||||
|
"u": "ᵘ",
|
||||||
|
"v": "ᵛ",
|
||||||
|
"w": "ʷ",
|
||||||
|
"x": "ˣ",
|
||||||
|
"y": "ʸ",
|
||||||
|
"z": "ᶻ"
|
||||||
|
}
|
13
srcs/compose/accent_tilde.json
Normal file
13
srcs/compose/accent_tilde.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"a": "ã",
|
||||||
|
"e": "ẽ",
|
||||||
|
"i": "ĩ",
|
||||||
|
"n": "ñ",
|
||||||
|
"o": "õ",
|
||||||
|
"u": "ũ",
|
||||||
|
"ă": "ẵ",
|
||||||
|
"â": "ẫ",
|
||||||
|
"ê": "ễ",
|
||||||
|
"ơ": "ỡ",
|
||||||
|
"ư": "ữ"
|
||||||
|
}
|
8
srcs/compose/accent_trema.json
Normal file
8
srcs/compose/accent_trema.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"a": "ä",
|
||||||
|
"e": "ë",
|
||||||
|
"i": "ï",
|
||||||
|
"o": "ö",
|
||||||
|
"u": "ü",
|
||||||
|
"y": "ÿ"
|
||||||
|
}
|
Binary file not shown.
@ -71,30 +71,30 @@ public final class KeyModifier
|
|||||||
case FN: return apply_fn(k);
|
case FN: return apply_fn(k);
|
||||||
case GESTURE: return apply_gesture(k);
|
case GESTURE: return apply_gesture(k);
|
||||||
case SHIFT: return apply_shift(k);
|
case SHIFT: return apply_shift(k);
|
||||||
case GRAVE: return apply_map_char(k, map_char_grave);
|
case GRAVE: return apply_compose_or_dead_char(k, ComposeKeyData.accent_grave, '\u02CB');
|
||||||
case AIGU: return apply_map_char(k, map_char_aigu);
|
case AIGU: return apply_compose_or_dead_char(k, ComposeKeyData.accent_aigu, '\u00B4');
|
||||||
case CIRCONFLEXE: return apply_map_char(k, map_char_circonflexe);
|
case CIRCONFLEXE: return apply_compose_or_dead_char(k, ComposeKeyData.accent_circonflexe, '\u02C6');
|
||||||
case TILDE: return apply_map_char(k, map_char_tilde);
|
case TILDE: return apply_compose_or_dead_char(k, ComposeKeyData.accent_tilde, '\u02DC');
|
||||||
case CEDILLE: return apply_map_char(k, map_char_cedille);
|
case CEDILLE: return apply_compose_or_dead_char(k, ComposeKeyData.accent_cedille, '\u00B8');
|
||||||
case TREMA: return apply_map_char(k, map_char_trema);
|
case TREMA: return apply_compose_or_dead_char(k, ComposeKeyData.accent_trema, '\u00A8');
|
||||||
case CARON: return apply_map_char(k, map_char_caron);
|
case CARON: return apply_compose_or_dead_char(k, ComposeKeyData.accent_caron, '\u02C7');
|
||||||
case RING: return apply_map_char(k, map_char_ring);
|
case RING: return apply_compose_or_dead_char(k, ComposeKeyData.accent_ring, '\u02DA');
|
||||||
case MACRON: return apply_map_char(k, map_char_macron);
|
case MACRON: return apply_compose_or_dead_char(k, ComposeKeyData.accent_macron, '\u00AF');
|
||||||
case OGONEK: return apply_map_char(k, map_char_ogonek);
|
case OGONEK: return apply_compose_or_dead_char(k, ComposeKeyData.accent_ogonek, '\u02DB');
|
||||||
case DOT_ABOVE: return apply_map_char(k, map_char_dot_above);
|
case DOT_ABOVE: return apply_compose_or_dead_char(k, ComposeKeyData.accent_dot_above, '\u02D9');
|
||||||
case BREVE: return apply_map_char(k, map_char_breve);
|
case BREVE: return apply_dead_char(k, '\u02D8');
|
||||||
case DOUBLE_AIGU: return apply_map_char(k, map_char_double_aigu);
|
case DOUBLE_AIGU: return apply_compose(k, ComposeKeyData.accent_double_aigu);
|
||||||
case ORDINAL: return apply_map_char(k, map_char_ordinal);
|
case ORDINAL: return apply_compose(k, ComposeKeyData.accent_ordinal);
|
||||||
case SUPERSCRIPT: return apply_map_char(k, map_char_superscript);
|
case SUPERSCRIPT: return apply_compose(k, ComposeKeyData.accent_superscript);
|
||||||
case SUBSCRIPT: return apply_map_char(k, map_char_subscript);
|
case SUBSCRIPT: return apply_compose(k, ComposeKeyData.accent_subscript);
|
||||||
case ARROWS: return apply_map_char(k, map_char_arrows);
|
case ARROWS: return apply_compose(k, ComposeKeyData.accent_arrows);
|
||||||
case BOX: return apply_map_char(k, map_char_box);
|
case BOX: return apply_compose(k, ComposeKeyData.accent_box);
|
||||||
case SLASH: return apply_map_char(k, map_char_slash);
|
case SLASH: return apply_compose(k, ComposeKeyData.accent_slash);
|
||||||
case BAR: return apply_map_char(k, map_char_bar);
|
case BAR: return apply_compose(k, ComposeKeyData.accent_bar);
|
||||||
|
case DOT_BELOW: return apply_compose(k, ComposeKeyData.accent_dot_below);
|
||||||
|
case HORN: return apply_compose(k, ComposeKeyData.accent_horn);
|
||||||
|
case HOOK_ABOVE: return apply_compose(k, ComposeKeyData.accent_hook_above);
|
||||||
case ARROW_RIGHT: return apply_map_char(k, map_char_arrow_right);
|
case ARROW_RIGHT: return apply_map_char(k, map_char_arrow_right);
|
||||||
case DOT_BELOW: return apply_map_char(k, map_char_dot_below);
|
|
||||||
case HORN: return apply_map_char(k, map_char_horn);
|
|
||||||
case HOOK_ABOVE: return apply_map_char(k, map_char_hook_above);
|
|
||||||
default: return k;
|
default: return k;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -145,6 +145,45 @@ public final class KeyModifier
|
|||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Apply the given compose state or fallback to the dead_char. */
|
||||||
|
private static KeyValue apply_compose_or_dead_char(KeyValue k, int state, char dead_char)
|
||||||
|
{
|
||||||
|
switch (k.getKind())
|
||||||
|
{
|
||||||
|
case Char:
|
||||||
|
char c = k.getChar();
|
||||||
|
KeyValue r = ComposeKey.apply(state, c);
|
||||||
|
if (r != null)
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
return apply_dead_char(k, dead_char);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static KeyValue apply_compose(KeyValue k, int state)
|
||||||
|
{
|
||||||
|
switch (k.getKind())
|
||||||
|
{
|
||||||
|
case Char:
|
||||||
|
KeyValue r = ComposeKey.apply(state, k.getChar());
|
||||||
|
if (r != null)
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
return k;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static KeyValue apply_dead_char(KeyValue k, char dead_char)
|
||||||
|
{
|
||||||
|
switch (k.getKind())
|
||||||
|
{
|
||||||
|
case Char:
|
||||||
|
char c = k.getChar();
|
||||||
|
char modified = (char)KeyCharacterMap.getDeadChar(dead_char, c);
|
||||||
|
if (modified != 0 && modified != c)
|
||||||
|
return KeyValue.makeStringKey(String.valueOf(modified));
|
||||||
|
}
|
||||||
|
return k;
|
||||||
|
}
|
||||||
|
|
||||||
private static KeyValue apply_shift(KeyValue k)
|
private static KeyValue apply_shift(KeyValue k)
|
||||||
{
|
{
|
||||||
if (_modmap != null)
|
if (_modmap != null)
|
||||||
@ -572,424 +611,6 @@ public final class KeyModifier
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Return [null] if the dead char do not apply. */
|
|
||||||
private static String map_dead_char(char c, char dead_char)
|
|
||||||
{
|
|
||||||
char modified = (char)KeyCharacterMap.getDeadChar(dead_char, c);
|
|
||||||
return (modified == 0 || modified == c) ? null : String.valueOf(modified);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final Map_char map_char_aigu =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "á";
|
|
||||||
case 'c': return "ć";
|
|
||||||
case 'e': return "é";
|
|
||||||
case 'i': return "í";
|
|
||||||
case 'l': return "ĺ";
|
|
||||||
case 'ń': return "ń";
|
|
||||||
case 'o': return "ó";
|
|
||||||
case 'r': return "ŕ";
|
|
||||||
case 's': return "ś";
|
|
||||||
case 'u': return "ú";
|
|
||||||
case 'y': return "ý";
|
|
||||||
case 'z': return "ź";
|
|
||||||
// used in Pinyin
|
|
||||||
case 'ü': return "ǘ";
|
|
||||||
// Combining diacritic
|
|
||||||
case 'j':
|
|
||||||
// Russian vowels
|
|
||||||
case 'у': case 'е': case 'а': case 'о': case 'и':
|
|
||||||
case 'ы': case 'э': case 'ю': case 'я':
|
|
||||||
return c + "\u0301";
|
|
||||||
default: return map_dead_char(c, '\u00B4');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_caron =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ǎ";
|
|
||||||
case 'c': return "č";
|
|
||||||
case 'd': return "ď";
|
|
||||||
case 'e': return "ě";
|
|
||||||
case 'i': return "ǐ";
|
|
||||||
case 'l': return "ľ";
|
|
||||||
case 'n': return "ň";
|
|
||||||
case 'o': return "ǒ";
|
|
||||||
case 'r': return "ř";
|
|
||||||
case 's': return "š";
|
|
||||||
case 't': return "ť";
|
|
||||||
case 'u': return "ǔ";
|
|
||||||
case 'z': return "ž";
|
|
||||||
// used in Pinyin
|
|
||||||
case 'ü': return "ǚ";
|
|
||||||
default: return map_dead_char(c, '\u02C7');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_cedille =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'c': return "ç";
|
|
||||||
case 'd': return "ḑ";
|
|
||||||
case 'e': return "ȩ";
|
|
||||||
case 'g': return "ģ";
|
|
||||||
case 'h': return "ḩ";
|
|
||||||
case 'k': return "ķ";
|
|
||||||
case 'l': return "ļ";
|
|
||||||
case 'n': return "ņ";
|
|
||||||
case 'r': return "ŗ";
|
|
||||||
case 's': return "ş";
|
|
||||||
case 't': return "ţ";
|
|
||||||
default: return map_dead_char(c, '\u00B8');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_circonflexe =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "â";
|
|
||||||
case 'c': return "ĉ";
|
|
||||||
case 'e': return "ê";
|
|
||||||
case 'g': return "ĝ";
|
|
||||||
case 'h': return "ĥ";
|
|
||||||
case 'i': return "î";
|
|
||||||
case 'j': return "ĵ";
|
|
||||||
case 'o': return "ô";
|
|
||||||
case 'ŝ': return "ŝ";
|
|
||||||
case 'u': return "û";
|
|
||||||
case 'z': return "ẑ";
|
|
||||||
default: return map_dead_char(c, '\u02C6');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_dot_above =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ȧ";
|
|
||||||
case 'b': return "ḃ";
|
|
||||||
case 'c': return "ċ";
|
|
||||||
case 'd': return "ḋ";
|
|
||||||
case 'e': return "ė";
|
|
||||||
case 'f': return "ḟ";
|
|
||||||
case 'g': return "ġ";
|
|
||||||
case 'h': return "ḣ";
|
|
||||||
// Turkish ı / İ is handled elsewhere
|
|
||||||
case 'm': return "ṁ";
|
|
||||||
case 'n': return "ṅ";
|
|
||||||
case 'o': return "ȯ";
|
|
||||||
case 'p': return "ṗ";
|
|
||||||
case 'r': return "ṙ";
|
|
||||||
case 's': return "ṡ";
|
|
||||||
case 't': return "ṫ";
|
|
||||||
case 'w': return "ẇ";
|
|
||||||
case 'x': return "ẋ";
|
|
||||||
case 'y': return "ẏ";
|
|
||||||
case 'z': return "ż";
|
|
||||||
default: return map_dead_char(c, '\u02D9');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_grave =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "à";
|
|
||||||
case 'e': return "è";
|
|
||||||
case 'i': return "ì";
|
|
||||||
case 'o': return "ò";
|
|
||||||
case 'u': return "ù";
|
|
||||||
// used in Pinyin
|
|
||||||
case 'ü': return "ǜ";
|
|
||||||
default: return map_dead_char(c, '\u02CB');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_macron =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ā";
|
|
||||||
case 'e': return "ē";
|
|
||||||
case 'i': return "ī";
|
|
||||||
case 'o': return "ō";
|
|
||||||
case 'u': return "ū";
|
|
||||||
// used in Pinyin
|
|
||||||
case 'ü': return "ǖ";
|
|
||||||
default: return map_dead_char(c, '\u00AF');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_ogonek =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ą";
|
|
||||||
case 'e': return "ę";
|
|
||||||
case 'i': return "į";
|
|
||||||
case 'k': return "ķ";
|
|
||||||
case 'l': return "ļ";
|
|
||||||
case 'n': return "ņ";
|
|
||||||
case 'o': return "ǫ";
|
|
||||||
case 'u': return "ų";
|
|
||||||
default: return map_dead_char(c, '\u02DB');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_ring =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "å";
|
|
||||||
case 'u': return "ů";
|
|
||||||
default: return map_dead_char(c, '\u02DA');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_tilde =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ã";
|
|
||||||
case 'e': return "ẽ";
|
|
||||||
case 'i': return "ĩ";
|
|
||||||
case 'n': return "ñ";
|
|
||||||
case 'o': return "õ";
|
|
||||||
case 'u': return "ũ";
|
|
||||||
// Vietnamese
|
|
||||||
case 'ă': return "ẵ";
|
|
||||||
case 'â': return "ẫ";
|
|
||||||
case 'ê': return "ễ";
|
|
||||||
case 'ơ': return "ỡ";
|
|
||||||
case 'ư': return "ữ";
|
|
||||||
default: return map_dead_char(c, '\u02DC');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_trema =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ä";
|
|
||||||
case 'e': return "ë";
|
|
||||||
case 'i': return "ï";
|
|
||||||
case 'o': return "ö";
|
|
||||||
case 'u': return "ü";
|
|
||||||
case 'y': return "ÿ";
|
|
||||||
default: return map_dead_char(c, '\u00A8');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_breve =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
default: return map_dead_char(c, '\u02D8');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_double_aigu =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'o': return "ő";
|
|
||||||
case 'u': return "ű";
|
|
||||||
case ' ': return "˝";
|
|
||||||
// Combining diacritic
|
|
||||||
case 'a':
|
|
||||||
case 'e':
|
|
||||||
case 'i':
|
|
||||||
case 'm':
|
|
||||||
case 'y':
|
|
||||||
return c + "\u030b";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_ordinal =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ª";
|
|
||||||
case 'o': return "º";
|
|
||||||
case '1': return "ª";
|
|
||||||
case '2': return "º";
|
|
||||||
case '3': return "ⁿ";
|
|
||||||
case '4': return "ᵈ";
|
|
||||||
case '5': return "ᵉ";
|
|
||||||
case '6': return "ʳ";
|
|
||||||
case '7': return "ˢ";
|
|
||||||
case '8': return "ᵗ";
|
|
||||||
case '9': return "ʰ";
|
|
||||||
case '*': return "°";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_superscript =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case '1': return "¹";
|
|
||||||
case '2': return "²";
|
|
||||||
case '3': return "³";
|
|
||||||
case '4': return "⁴";
|
|
||||||
case '5': return "⁵";
|
|
||||||
case '6': return "⁶";
|
|
||||||
case '7': return "⁷";
|
|
||||||
case '8': return "⁸";
|
|
||||||
case '9': return "⁹";
|
|
||||||
case '0': return "⁰";
|
|
||||||
case '+': return "⁺";
|
|
||||||
case '-': return "⁻";
|
|
||||||
case '=': return "⁼";
|
|
||||||
case '(': return "⁽";
|
|
||||||
case ')': return "⁾";
|
|
||||||
case 'a': return "ᵃ";
|
|
||||||
case 'b': return "ᵇ";
|
|
||||||
case 'c': return "ᶜ";
|
|
||||||
case 'd': return "ᵈ";
|
|
||||||
case 'e': return "ᵉ";
|
|
||||||
case 'f': return "ᶠ";
|
|
||||||
case 'g': return "ᵍ";
|
|
||||||
case 'h': return "ʰ";
|
|
||||||
case 'i': return "ⁱ";
|
|
||||||
case 'j': return "ʲ";
|
|
||||||
case 'k': return "ᵏ";
|
|
||||||
case 'l': return "ˡ";
|
|
||||||
case 'm': return "ᵐ";
|
|
||||||
case 'n': return "ⁿ";
|
|
||||||
case 'o': return "ᵒ";
|
|
||||||
case 'p': return "ᵖ";
|
|
||||||
case 'r': return "ʳ";
|
|
||||||
case 's': return "ˢ";
|
|
||||||
case 't': return "ᵗ";
|
|
||||||
case 'u': return "ᵘ";
|
|
||||||
case 'v': return "ᵛ";
|
|
||||||
case 'w': return "ʷ";
|
|
||||||
case 'x': return "ˣ";
|
|
||||||
case 'y': return "ʸ";
|
|
||||||
case 'z': return "ᶻ";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_subscript =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case '1': return "₁";
|
|
||||||
case '2': return "₂";
|
|
||||||
case '3': return "₃";
|
|
||||||
case '4': return "₄";
|
|
||||||
case '5': return "₅";
|
|
||||||
case '6': return "₆";
|
|
||||||
case '7': return "₇";
|
|
||||||
case '8': return "₈";
|
|
||||||
case '9': return "₉";
|
|
||||||
case '0': return "₀";
|
|
||||||
case '+': return "₊";
|
|
||||||
case '-': return "₋";
|
|
||||||
case '=': return "₌";
|
|
||||||
case '(': return "₍";
|
|
||||||
case ')': return "₎";
|
|
||||||
case 'a': return "ₐ";
|
|
||||||
case 'e': return "ₑ";
|
|
||||||
case 'h': return "ₕ";
|
|
||||||
case 'i': return "ᵢ";
|
|
||||||
case 'j': return "ⱼ";
|
|
||||||
case 'k': return "ₖ";
|
|
||||||
case 'l': return "ₗ";
|
|
||||||
case 'm': return "ₘ";
|
|
||||||
case 'n': return "ₙ";
|
|
||||||
case 'o': return "ₒ";
|
|
||||||
case 'p': return "ₚ";
|
|
||||||
case 'r': return "ᵣ";
|
|
||||||
case 's': return "ₛ";
|
|
||||||
case 't': return "ₜ";
|
|
||||||
case 'u': return "ᵤ";
|
|
||||||
case 'v': return "ᵥ";
|
|
||||||
case 'x': return "ₓ";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_arrows =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case '0': return "↔";
|
|
||||||
case '1': return "↙";
|
|
||||||
case '2': return "↓";
|
|
||||||
case '3': return "↘";
|
|
||||||
case '4': return "←";
|
|
||||||
case '5': return "↕";
|
|
||||||
case '6': return "→";
|
|
||||||
case '7': return "↖";
|
|
||||||
case '8': return "↑";
|
|
||||||
case '9': return "↗";
|
|
||||||
case '.': return "↵";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_arrow_right =
|
private static final Map_char map_char_arrow_right =
|
||||||
new Map_char() {
|
new Map_char() {
|
||||||
public String apply(char c)
|
public String apply(char c)
|
||||||
@ -1001,147 +622,6 @@ public final class KeyModifier
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
private static final Map_char map_char_box =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case '1': return "└";
|
|
||||||
case '2': return "┴";
|
|
||||||
case '3': return "┘";
|
|
||||||
case '4': return "├";
|
|
||||||
case '5': return "┼";
|
|
||||||
case '6': return "┤";
|
|
||||||
case '7': return "┌";
|
|
||||||
case '8': return "┬";
|
|
||||||
case '9': return "┐";
|
|
||||||
case '0': return "─";
|
|
||||||
case '.': return "│";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_slash =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ⱥ";
|
|
||||||
case 'b': return "␢";
|
|
||||||
case 'c': return "ȼ";
|
|
||||||
case 'e': return "ɇ";
|
|
||||||
case 'g': return "ꞡ";
|
|
||||||
case 'k': return "ꝃ";
|
|
||||||
case 'l': return "ł";
|
|
||||||
case 'n': return "ꞥ";
|
|
||||||
case 'o': return "ø";
|
|
||||||
case 'r': return "ꞧ";
|
|
||||||
case 's': return "ꞩ";
|
|
||||||
case 't': return "ⱦ";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_bar =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'b': return "ƀ";
|
|
||||||
case 'c': return "ꞓ";
|
|
||||||
case 'd': return "đ";
|
|
||||||
case 'g': return "ǥ";
|
|
||||||
case 'i': return "ɨ";
|
|
||||||
case 'j': return "ɉ";
|
|
||||||
case 'k': return "ꝁ";
|
|
||||||
case 'l': return "ƚ";
|
|
||||||
case 'o': return "ɵ";
|
|
||||||
case 'p': return "ᵽ";
|
|
||||||
case 'q': return "ꝗ";
|
|
||||||
case 'r': return "ɍ";
|
|
||||||
case 't': return "ŧ";
|
|
||||||
case 'u': return "ʉ";
|
|
||||||
case 'y': return "ɏ";
|
|
||||||
case 'z': return "ƶ";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_dot_below =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ạ";
|
|
||||||
case 'ă': return "ặ";
|
|
||||||
case 'â': return "ậ";
|
|
||||||
case 'e': return "ẹ";
|
|
||||||
case 'ê': return "ệ";
|
|
||||||
case 'i': return "ị";
|
|
||||||
case 'o': return "ọ";
|
|
||||||
case 'ô': return "ộ";
|
|
||||||
case 'ơ': return "ợ";
|
|
||||||
case 'u': return "ụ";
|
|
||||||
case 'ư': return "ự";
|
|
||||||
case 'y': return "ỵ";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_horn =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'o': return "ơ";
|
|
||||||
case 'ó': return "ớ";
|
|
||||||
case 'ò': return "ờ";
|
|
||||||
case 'ỏ': return "ở";
|
|
||||||
case 'õ': return "ỡ";
|
|
||||||
case 'ọ': return "ợ";
|
|
||||||
case 'u': return "ư";
|
|
||||||
case 'ú': return "ứ";
|
|
||||||
case 'ù': return "ừ";
|
|
||||||
case 'ủ': return "ử";
|
|
||||||
case 'ũ': return "ữ";
|
|
||||||
case 'ụ': return "ự";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private static final Map_char map_char_hook_above =
|
|
||||||
new Map_char() {
|
|
||||||
public String apply(char c)
|
|
||||||
{
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case 'a': return "ả";
|
|
||||||
case 'ă': return "ẳ";
|
|
||||||
case 'â': return "ẩ";
|
|
||||||
case 'e': return "ẻ";
|
|
||||||
case 'ê': return "ể";
|
|
||||||
case 'i': return "ỉ";
|
|
||||||
case 'o': return "ỏ";
|
|
||||||
case 'ô': return "ổ";
|
|
||||||
case 'ơ': return "ở";
|
|
||||||
case 'u': return "ủ";
|
|
||||||
case 'ư': return "ử";
|
|
||||||
case 'y': return "ỷ";
|
|
||||||
default: return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Used with Arabic despite the name; called "Hindi numerals" in Arabic
|
// Used with Arabic despite the name; called "Hindi numerals" in Arabic
|
||||||
// map_char_numpad_devanagari is used in Hindi
|
// map_char_numpad_devanagari is used in Hindi
|
||||||
private static final Map_char map_char_numpad_hindu =
|
private static final Map_char map_char_numpad_hindu =
|
||||||
|
Loading…
Reference in New Issue
Block a user