mirror of
https://github.com/BoredDevNL/BoredOS.git
synced 2026-05-15 10:48:38 +00:00
fix(input): refine legacy key mapping and ensure codepoints on release
This commit is contained in:
parent
963e68162b
commit
3bb90a8b7f
3 changed files with 26 additions and 23 deletions
|
|
@ -188,12 +188,13 @@ bool keyboard_handle_set1_scancode(uint8_t scancode, keyboard_event_t *ev) {
|
||||||
ev->pressed = pressed;
|
ev->pressed = pressed;
|
||||||
ev->mods = keyboard_get_modifiers();
|
ev->mods = keyboard_get_modifiers();
|
||||||
|
|
||||||
|
keymap_result_t r = keymap_translate_keycode(keycode, ev->mods);
|
||||||
|
ev->codepoint = r.codepoint;
|
||||||
|
|
||||||
if (!pressed) {
|
if (!pressed) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
keymap_result_t r = keymap_translate_keycode(keycode, ev->mods);
|
|
||||||
|
|
||||||
if (r.is_dead) {
|
if (r.is_dead) {
|
||||||
g_kb.dead_key = r.codepoint;
|
g_kb.dead_key = r.codepoint;
|
||||||
return true;
|
return true;
|
||||||
|
|
|
||||||
|
|
@ -434,32 +434,34 @@ int keymap_legacy_key(uint16_t keycode, uint32_t codepoint) {
|
||||||
case KEY_ENTER:
|
case KEY_ENTER:
|
||||||
case KEY_KP_ENTER: return '\n';
|
case KEY_KP_ENTER: return '\n';
|
||||||
|
|
||||||
|
case KEY_SPACE: return ' ';
|
||||||
|
|
||||||
case KEY_ARROW_UP: return 17;
|
case KEY_ARROW_UP: return 17;
|
||||||
case KEY_ARROW_DOWN: return 18;
|
case KEY_ARROW_DOWN: return 18;
|
||||||
case KEY_ARROW_LEFT: return 19;
|
case KEY_ARROW_LEFT: return 19;
|
||||||
case KEY_ARROW_RIGHT: return 20;
|
case KEY_ARROW_RIGHT: return 20;
|
||||||
|
|
||||||
case KEY_LEFT_CTRL:
|
case KEY_LEFT_CTRL:
|
||||||
case KEY_RIGHT_CTRL: return 21;
|
case KEY_RIGHT_CTRL: return 161;
|
||||||
case KEY_LEFT_SHIFT:
|
case KEY_LEFT_SHIFT:
|
||||||
case KEY_RIGHT_SHIFT: return 24;
|
case KEY_RIGHT_SHIFT: return 162;
|
||||||
case KEY_LEFT_ALT: return 25;
|
case KEY_LEFT_ALT: return 163;
|
||||||
case KEY_RIGHT_ALT: return 22; // for compat w/ doom
|
case KEY_RIGHT_ALT: return 22; // for compat w/ doom
|
||||||
case KEY_CAPS_LOCK: return 23; // same here
|
case KEY_CAPS_LOCK: return 23; // same here
|
||||||
case KEY_DELETE: return 127;
|
case KEY_DELETE: return 127;
|
||||||
|
|
||||||
case KEY_F1: return 31;
|
case KEY_F1: return 141;
|
||||||
case KEY_F2: return 32;
|
case KEY_F2: return 142;
|
||||||
case KEY_F3: return 33;
|
case KEY_F3: return 143;
|
||||||
case KEY_F4: return 34;
|
case KEY_F4: return 144;
|
||||||
case KEY_F5: return 35;
|
case KEY_F5: return 145;
|
||||||
case KEY_F6: return 36;
|
case KEY_F6: return 146;
|
||||||
case KEY_F7: return 37;
|
case KEY_F7: return 147;
|
||||||
case KEY_F8: return 38;
|
case KEY_F8: return 148;
|
||||||
case KEY_F9: return 39;
|
case KEY_F9: return 149;
|
||||||
case KEY_F10: return 40;
|
case KEY_F10: return 150;
|
||||||
case KEY_F11: return 41;
|
case KEY_F11: return 151;
|
||||||
case KEY_F12: return 42;
|
case KEY_F12: return 152;
|
||||||
|
|
||||||
default: return 0;
|
default: return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -93,18 +93,18 @@ int DG_GetKey(int* pressed, unsigned char* key) {
|
||||||
else if (k == 18) dk = KEY_DOWNARROW;
|
else if (k == 18) dk = KEY_DOWNARROW;
|
||||||
else if (k == 19) dk = KEY_LEFTARROW;
|
else if (k == 19) dk = KEY_LEFTARROW;
|
||||||
else if (k == 20) dk = KEY_RIGHTARROW;
|
else if (k == 20) dk = KEY_RIGHTARROW;
|
||||||
else if (k == 21) dk = KEY_FIRE;
|
else if (k == 161) dk = KEY_FIRE;
|
||||||
else if (k == 22) dk = KEY_RALT;
|
else if (k == 22) dk = KEY_RALT;
|
||||||
else if (k == 23) dk = KEY_CAPSLOCK;
|
else if (k == 23) dk = KEY_CAPSLOCK;
|
||||||
else if (k == 24) dk = KEY_RSHIFT;
|
else if (k == 162) dk = KEY_RSHIFT;
|
||||||
else if (k == 25) dk = KEY_LALT;
|
else if (k == 163) dk = KEY_LALT;
|
||||||
else if (k == 27) dk = KEY_ESCAPE;
|
else if (k == 27) dk = KEY_ESCAPE;
|
||||||
else if (k == '\b') dk = KEY_BACKSPACE;
|
else if (k == '\b') dk = KEY_BACKSPACE;
|
||||||
else if (k == '\t') dk = KEY_TAB;
|
else if (k == '\t') dk = KEY_TAB;
|
||||||
else if (k == 127) dk = KEY_DEL;
|
else if (k == 127) dk = KEY_DEL;
|
||||||
else if (k >= 31 && k <= 40) dk = KEY_F1 + (k - 31);
|
else if (k >= 141 && k <= 150) dk = KEY_F1 + (k - 141);
|
||||||
else if (k == 41) dk = KEY_F11;
|
else if (k == 151) dk = KEY_F11;
|
||||||
else if (k == 42) dk = KEY_F12;
|
else if (k == 152) dk = KEY_F12;
|
||||||
else if (k == ' ') dk = KEY_USE;
|
else if (k == ' ') dk = KEY_USE;
|
||||||
else if (k == '\n' || k == '\r') dk = KEY_ENTER;
|
else if (k == '\n' || k == '\r') dk = KEY_ENTER;
|
||||||
else if (k >= 'A' && k <= 'Z') dk = k + 32;
|
else if (k >= 'A' && k <= 'Z') dk = k + 32;
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue