diff options
Diffstat (limited to 'quantum/process_keycode/process_unicode.c')
-rw-r--r-- | quantum/process_keycode/process_unicode.c | 93 |
1 files changed, 92 insertions, 1 deletions
diff --git a/quantum/process_keycode/process_unicode.c b/quantum/process_keycode/process_unicode.c index 55e47f179..8a6509300 100644 --- a/quantum/process_keycode/process_unicode.c +++ b/quantum/process_keycode/process_unicode.c | |||
@@ -68,4 +68,95 @@ bool process_unicode(uint16_t keycode, keyrecord_t *record) { | |||
68 | unicode_input_finish(); | 68 | unicode_input_finish(); |
69 | } | 69 | } |
70 | return true; | 70 | return true; |
71 | } \ No newline at end of file | 71 | } |
72 | |||
73 | #ifdef UCIS_ENABLE | ||
74 | void qk_ucis_start(void) { | ||
75 | qk_ucis_state.count = 0; | ||
76 | qk_ucis_state.in_progress = true; | ||
77 | |||
78 | unicode_input_start(); | ||
79 | register_hex(0x2328); | ||
80 | unicode_input_finish(); | ||
81 | } | ||
82 | |||
83 | static bool is_uni_seq(char *seq) { | ||
84 | uint8_t i; | ||
85 | |||
86 | for (i = 0; seq[i]; i++) { | ||
87 | uint16_t code; | ||
88 | if (('1' <= seq[i]) && (seq[i] <= '0')) | ||
89 | code = seq[i] - '1' + KC_1; | ||
90 | else | ||
91 | code = seq[i] - 'a' + KC_A; | ||
92 | |||
93 | if (i > qk_ucis_state.count || qk_ucis_state.codes[i] != code) | ||
94 | return false; | ||
95 | } | ||
96 | |||
97 | return (qk_ucis_state.codes[i] == KC_ENT || | ||
98 | qk_ucis_state.codes[i] == KC_SPC); | ||
99 | } | ||
100 | |||
101 | __attribute__((weak)) | ||
102 | void qk_ucis_symbol_fallback (void) { | ||
103 | for (uint8_t i = 0; i < qk_ucis_state.count - 1; i++) { | ||
104 | uint8_t code = qk_ucis_state.codes[i]; | ||
105 | register_code(code); | ||
106 | unregister_code(code); | ||
107 | } | ||
108 | } | ||
109 | |||
110 | bool process_record_ucis (uint16_t keycode, keyrecord_t *record) { | ||
111 | uint8_t i; | ||
112 | |||
113 | if (!qk_ucis_state.in_progress || !record->event.pressed) | ||
114 | return true; | ||
115 | |||
116 | qk_ucis_state.codes[qk_ucis_state.count] = keycode; | ||
117 | qk_ucis_state.count++; | ||
118 | |||
119 | if (keycode == KC_BSPC) { | ||
120 | if (qk_ucis_state.count >= 2) { | ||
121 | qk_ucis_state.count -= 2; | ||
122 | return true; | ||
123 | } else { | ||
124 | qk_ucis_state.count--; | ||
125 | return false; | ||
126 | } | ||
127 | } | ||
128 | |||
129 | if (keycode == KC_ENT || keycode == KC_SPC || keycode == KC_ESC) { | ||
130 | bool symbol_found = false; | ||
131 | |||
132 | for (i = qk_ucis_state.count; i > 0; i--) { | ||
133 | register_code (KC_BSPC); | ||
134 | unregister_code (KC_BSPC); | ||
135 | } | ||
136 | |||
137 | if (keycode == KC_ESC) { | ||
138 | qk_ucis_state.in_progress = false; | ||
139 | return false; | ||
140 | } | ||
141 | |||
142 | unicode_input_start(); | ||
143 | for (i = 0; ucis_symbol_table[i].symbol; i++) { | ||
144 | if (is_uni_seq (ucis_symbol_table[i].symbol)) { | ||
145 | symbol_found = true; | ||
146 | for (uint8_t j = 0; ucis_symbol_table[i].codes[j]; j++) { | ||
147 | register_hex(ucis_symbol_table[i].codes[j]); | ||
148 | } | ||
149 | break; | ||
150 | } | ||
151 | } | ||
152 | if (!symbol_found) { | ||
153 | qk_ucis_symbol_fallback(); | ||
154 | } | ||
155 | unicode_input_finish(); | ||
156 | |||
157 | qk_ucis_state.in_progress = false; | ||
158 | return false; | ||
159 | } | ||
160 | return true; | ||
161 | } | ||
162 | #endif | ||