Numpad scancodes have non-numpad keycodes

This allows the numpad to work as the user expects based on the numlock state. If the application needs to distinguish the keys, it can check to see whether the scancode is a numpad key or not.
This commit is contained in:
Sam Lantinga 2024-06-30 23:35:23 -07:00
parent 78dbf9be50
commit d4497ecdbd
8 changed files with 316 additions and 352 deletions

View file

@ -125,6 +125,7 @@ typedef Uint32 SDL_Keycode;
#define SDLK_RIGHTBRACE 0x0000007du /* '}' */ #define SDLK_RIGHTBRACE 0x0000007du /* '}' */
#define SDLK_TILDE 0x0000007eu /* '~' */ #define SDLK_TILDE 0x0000007eu /* '~' */
#define SDLK_DELETE 0x0000007fu /* '\x7F' */ #define SDLK_DELETE 0x0000007fu /* '\x7F' */
#define SDLK_PLUSMINUS 0x000000b1u /* '±' */
#define SDLK_CAPSLOCK 0x40000039u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CAPSLOCK) */ #define SDLK_CAPSLOCK 0x40000039u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CAPSLOCK) */
#define SDLK_F1 0x4000003au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F1) */ #define SDLK_F1 0x4000003au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F1) */
#define SDLK_F2 0x4000003bu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F2) */ #define SDLK_F2 0x4000003bu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F2) */
@ -151,25 +152,8 @@ typedef Uint32 SDL_Keycode;
#define SDLK_DOWN 0x40000051u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DOWN) */ #define SDLK_DOWN 0x40000051u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DOWN) */
#define SDLK_UP 0x40000052u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_UP) */ #define SDLK_UP 0x40000052u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_UP) */
#define SDLK_NUMLOCKCLEAR 0x40000053u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_NUMLOCKCLEAR) */ #define SDLK_NUMLOCKCLEAR 0x40000053u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_NUMLOCKCLEAR) */
#define SDLK_KP_DIVIDE 0x40000054u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DIVIDE) */
#define SDLK_KP_MULTIPLY 0x40000055u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MULTIPLY) */
#define SDLK_KP_MINUS 0x40000056u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MINUS) */
#define SDLK_KP_PLUS 0x40000057u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PLUS) */
#define SDLK_KP_ENTER 0x40000058u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_ENTER) */
#define SDLK_KP_1 0x40000059u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_1) */
#define SDLK_KP_2 0x4000005au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_2) */
#define SDLK_KP_3 0x4000005bu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_3) */
#define SDLK_KP_4 0x4000005cu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_4) */
#define SDLK_KP_5 0x4000005du /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_5) */
#define SDLK_KP_6 0x4000005eu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_6) */
#define SDLK_KP_7 0x4000005fu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_7) */
#define SDLK_KP_8 0x40000060u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_8) */
#define SDLK_KP_9 0x40000061u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_9) */
#define SDLK_KP_0 0x40000062u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_0) */
#define SDLK_KP_PERIOD 0x40000063u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PERIOD) */
#define SDLK_APPLICATION 0x40000065u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_APPLICATION) */ #define SDLK_APPLICATION 0x40000065u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_APPLICATION) */
#define SDLK_POWER 0x40000066u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_POWER) */ #define SDLK_POWER 0x40000066u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_POWER) */
#define SDLK_KP_EQUALS 0x40000067u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EQUALS) */
#define SDLK_F13 0x40000068u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F13) */ #define SDLK_F13 0x40000068u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F13) */
#define SDLK_F14 0x40000069u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F14) */ #define SDLK_F14 0x40000069u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F14) */
#define SDLK_F15 0x4000006au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F15) */ #define SDLK_F15 0x4000006au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F15) */
@ -196,8 +180,6 @@ typedef Uint32 SDL_Keycode;
#define SDLK_MUTE 0x4000007fu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MUTE) */ #define SDLK_MUTE 0x4000007fu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MUTE) */
#define SDLK_VOLUMEUP 0x40000080u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEUP) */ #define SDLK_VOLUMEUP 0x40000080u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEUP) */
#define SDLK_VOLUMEDOWN 0x40000081u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEDOWN) */ #define SDLK_VOLUMEDOWN 0x40000081u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEDOWN) */
#define SDLK_KP_COMMA 0x40000085u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_COMMA) */
#define SDLK_KP_EQUALSAS400 0x40000086u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EQUALSAS400) */
#define SDLK_ALTERASE 0x40000099u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_ALTERASE) */ #define SDLK_ALTERASE 0x40000099u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_ALTERASE) */
#define SDLK_SYSREQ 0x4000009au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SYSREQ) */ #define SDLK_SYSREQ 0x4000009au /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SYSREQ) */
#define SDLK_CANCEL 0x4000009bu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CANCEL) */ #define SDLK_CANCEL 0x4000009bu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CANCEL) */
@ -216,32 +198,11 @@ typedef Uint32 SDL_Keycode;
#define SDLK_DECIMALSEPARATOR 0x400000b3u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DECIMALSEPARATOR) */ #define SDLK_DECIMALSEPARATOR 0x400000b3u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DECIMALSEPARATOR) */
#define SDLK_CURRENCYUNIT 0x400000b4u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYUNIT) */ #define SDLK_CURRENCYUNIT 0x400000b4u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYUNIT) */
#define SDLK_CURRENCYSUBUNIT 0x400000b5u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYSUBUNIT) */ #define SDLK_CURRENCYSUBUNIT 0x400000b5u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYSUBUNIT) */
#define SDLK_KP_LEFTPAREN 0x400000b6u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LEFTPAREN) */
#define SDLK_KP_RIGHTPAREN 0x400000b7u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_RIGHTPAREN) */
#define SDLK_KP_LEFTBRACE 0x400000b8u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LEFTBRACE) */
#define SDLK_KP_RIGHTBRACE 0x400000b9u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_RIGHTBRACE) */
#define SDLK_KP_TAB 0x400000bau /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_TAB) */
#define SDLK_KP_BACKSPACE 0x400000bbu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BACKSPACE) */
#define SDLK_KP_A 0x400000bcu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_A) */
#define SDLK_KP_B 0x400000bdu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_B) */
#define SDLK_KP_C 0x400000beu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_C) */
#define SDLK_KP_D 0x400000bfu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_D) */
#define SDLK_KP_E 0x400000c0u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_E) */
#define SDLK_KP_F 0x400000c1u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_F) */
#define SDLK_KP_XOR 0x400000c2u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_XOR) */ #define SDLK_KP_XOR 0x400000c2u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_XOR) */
#define SDLK_KP_POWER 0x400000c3u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_POWER) */ #define SDLK_KP_POWER 0x400000c3u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_POWER) */
#define SDLK_KP_PERCENT 0x400000c4u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PERCENT) */
#define SDLK_KP_LESS 0x400000c5u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LESS) */
#define SDLK_KP_GREATER 0x400000c6u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_GREATER) */
#define SDLK_KP_AMPERSAND 0x400000c7u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_AMPERSAND) */
#define SDLK_KP_DBLAMPERSAND 0x400000c8u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLAMPERSAND) */ #define SDLK_KP_DBLAMPERSAND 0x400000c8u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLAMPERSAND) */
#define SDLK_KP_VERTICALBAR 0x400000c9u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_VERTICALBAR) */ #define SDLK_KP_VERTICALBAR 0x400000c9u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_VERTICALBAR) */
#define SDLK_KP_DBLVERTICALBAR 0x400000cau /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLVERTICALBAR) */ #define SDLK_KP_DBLVERTICALBAR 0x400000cau /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLVERTICALBAR) */
#define SDLK_KP_COLON 0x400000cbu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_COLON) */
#define SDLK_KP_HASH 0x400000ccu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_HASH) */
#define SDLK_KP_SPACE 0x400000cdu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_SPACE) */
#define SDLK_KP_AT 0x400000ceu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_AT) */
#define SDLK_KP_EXCLAM 0x400000cfu /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EXCLAM) */
#define SDLK_KP_MEMSTORE 0x400000d0u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSTORE) */ #define SDLK_KP_MEMSTORE 0x400000d0u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSTORE) */
#define SDLK_KP_MEMRECALL 0x400000d1u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMRECALL) */ #define SDLK_KP_MEMRECALL 0x400000d1u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMRECALL) */
#define SDLK_KP_MEMCLEAR 0x400000d2u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMCLEAR) */ #define SDLK_KP_MEMCLEAR 0x400000d2u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMCLEAR) */
@ -249,7 +210,6 @@ typedef Uint32 SDL_Keycode;
#define SDLK_KP_MEMSUBTRACT 0x400000d4u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSUBTRACT) */ #define SDLK_KP_MEMSUBTRACT 0x400000d4u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSUBTRACT) */
#define SDLK_KP_MEMMULTIPLY 0x400000d5u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMMULTIPLY) */ #define SDLK_KP_MEMMULTIPLY 0x400000d5u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMMULTIPLY) */
#define SDLK_KP_MEMDIVIDE 0x400000d6u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMDIVIDE) */ #define SDLK_KP_MEMDIVIDE 0x400000d6u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMDIVIDE) */
#define SDLK_KP_PLUSMINUS 0x400000d7u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PLUSMINUS) */
#define SDLK_KP_CLEAR 0x400000d8u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEAR) */ #define SDLK_KP_CLEAR 0x400000d8u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEAR) */
#define SDLK_KP_CLEARENTRY 0x400000d9u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEARENTRY) */ #define SDLK_KP_CLEARENTRY 0x400000d9u /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEARENTRY) */
#define SDLK_KP_BINARY 0x400000dau /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BINARY) */ #define SDLK_KP_BINARY 0x400000dau /* SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BINARY) */

View file

@ -334,8 +334,8 @@ static SDL_Keycode SDL_GetEventKeycode(SDL_Keyboard *keyboard, SDL_Scancode scan
{ {
SDL_bool shifted = (modstate & SDL_KMOD_SHIFT) != 0; SDL_bool shifted = (modstate & SDL_KMOD_SHIFT) != 0;
// We won't be applying any modifiers by default // We won't be applying any modifiers except numlock by default
modstate = SDL_KMOD_NONE; modstate &= SDL_KMOD_NUM;
if (scancode >= SDL_SCANCODE_A && scancode <= SDL_SCANCODE_Z) { if (scancode >= SDL_SCANCODE_A && scancode <= SDL_SCANCODE_Z) {
if (keyboard->non_latin_letters && (keyboard->keycode_options & KEYCODE_OPTION_LATIN_LETTERS)) { if (keyboard->non_latin_letters && (keyboard->keycode_options & KEYCODE_OPTION_LATIN_LETTERS)) {

View file

@ -236,12 +236,95 @@ SDL_Keycode SDL_GetDefaultKeyFromScancode(SDL_Scancode scancode, SDL_Keymod mods
} }
} }
if (scancode == SDL_SCANCODE_DELETE) { switch (scancode) {
case SDL_SCANCODE_DELETE:
return SDLK_DELETE; return SDLK_DELETE;
} case SDL_SCANCODE_KP_DIVIDE:
return SDLK_SLASH;
case SDL_SCANCODE_KP_MULTIPLY:
return SDLK_ASTERISK;
case SDL_SCANCODE_KP_MINUS:
return SDLK_MINUS;
case SDL_SCANCODE_KP_PLUS:
return SDLK_PLUS;
case SDL_SCANCODE_KP_ENTER:
return SDLK_RETURN;
case SDL_SCANCODE_KP_1:
return (modstate & SDL_KMOD_NUM) ? SDLK_1 : SDLK_END;
case SDL_SCANCODE_KP_2:
return (modstate & SDL_KMOD_NUM) ? SDLK_2 : SDLK_DOWN;
case SDL_SCANCODE_KP_3:
return (modstate & SDL_KMOD_NUM) ? SDLK_3 : SDLK_PAGEDOWN;
case SDL_SCANCODE_KP_4:
return (modstate & SDL_KMOD_NUM) ? SDLK_4 : SDLK_LEFT;
case SDL_SCANCODE_KP_5:
return (modstate & SDL_KMOD_NUM) ? SDLK_5 : SDLK_CLEAR;
case SDL_SCANCODE_KP_6:
return (modstate & SDL_KMOD_NUM) ? SDLK_6 : SDLK_RIGHT;
case SDL_SCANCODE_KP_7:
return (modstate & SDL_KMOD_NUM) ? SDLK_7 : SDLK_HOME;
case SDL_SCANCODE_KP_8:
return (modstate & SDL_KMOD_NUM) ? SDLK_8 : SDLK_UP;
case SDL_SCANCODE_KP_9:
return (modstate & SDL_KMOD_NUM) ? SDLK_9 : SDLK_PAGEUP;
case SDL_SCANCODE_KP_0:
return (modstate & SDL_KMOD_NUM) ? SDLK_0 : SDLK_INSERT;
case SDL_SCANCODE_KP_PERIOD:
return (modstate & SDL_KMOD_NUM) ? SDLK_PERIOD : SDLK_DELETE;
case SDL_SCANCODE_KP_EQUALS:
return SDLK_EQUALS;
case SDL_SCANCODE_KP_COMMA:
return SDLK_COMMA;
case SDL_SCANCODE_KP_EQUALSAS400:
return SDLK_EQUALS;
case SDL_SCANCODE_KP_LEFTPAREN:
return SDLK_LEFTPAREN;
case SDL_SCANCODE_KP_RIGHTPAREN:
return SDLK_RIGHTPAREN;
case SDL_SCANCODE_KP_LEFTBRACE:
return SDLK_LEFTBRACE;
case SDL_SCANCODE_KP_RIGHTBRACE:
return SDLK_RIGHTBRACE;
case SDL_SCANCODE_KP_TAB:
return SDLK_TAB;
case SDL_SCANCODE_KP_BACKSPACE:
return SDLK_BACKSPACE;
case SDL_SCANCODE_KP_A:
return SDLK_A;
case SDL_SCANCODE_KP_B:
return SDLK_B;
case SDL_SCANCODE_KP_C:
return SDLK_C;
case SDL_SCANCODE_KP_D:
return SDLK_D;
case SDL_SCANCODE_KP_E:
return SDLK_E;
case SDL_SCANCODE_KP_F:
return SDLK_F;
case SDL_SCANCODE_KP_PERCENT:
return SDLK_PERCENT;
case SDL_SCANCODE_KP_LESS:
return SDLK_LESS;
case SDL_SCANCODE_KP_GREATER:
return SDLK_GREATER;
case SDL_SCANCODE_KP_AMPERSAND:
return SDLK_AMPERSAND;
case SDL_SCANCODE_KP_COLON:
return SDLK_COLON;
case SDL_SCANCODE_KP_HASH:
return SDLK_HASH;
case SDL_SCANCODE_KP_SPACE:
return SDLK_SPACE;
case SDL_SCANCODE_KP_AT:
return SDLK_AT;
case SDL_SCANCODE_KP_EXCLAM:
return SDLK_EXCLAIM;
case SDL_SCANCODE_KP_PLUSMINUS:
return SDLK_PLUSMINUS;
default:
return SDL_SCANCODE_TO_KEYCODE(scancode); return SDL_SCANCODE_TO_KEYCODE(scancode);
} }
}
SDL_Scancode SDL_GetDefaultScancodeFromKey(SDL_Keycode key, SDL_Keymod *modstate) SDL_Scancode SDL_GetDefaultScancodeFromKey(SDL_Keycode key, SDL_Keymod *modstate)
{ {

View file

@ -288,7 +288,7 @@ static void UpdateKeymap(SDL_CocoaVideoData *data, SDL_bool send_event)
/* Make sure this scancode is a valid character scancode */ /* Make sure this scancode is a valid character scancode */
SDL_Scancode scancode = darwin_scancode_table[i]; SDL_Scancode scancode = darwin_scancode_table[i];
if (scancode == SDL_SCANCODE_UNKNOWN || if (scancode == SDL_SCANCODE_UNKNOWN ||
(SDL_GetDefaultKeyFromScancode(scancode, SDL_KMOD_NONE) & SDLK_SCANCODE_MASK)) { scancode >= SDL_SCANCODE_CAPSLOCK) {
continue; continue;
} }

View file

@ -39,229 +39,229 @@ https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent
https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode
*/ */
static const SDL_Keycode emscripten_keycode_table[] = { static const SDL_Keycode emscripten_keycode_table[] = {
/* 0 */ SDLK_UNKNOWN, /* 0, 0x00 */ SDLK_UNKNOWN,
/* 1 */ SDLK_UNKNOWN, /* 1, 0x01 */ SDLK_UNKNOWN,
/* 2 */ SDLK_UNKNOWN, /* 2, 0x02 */ SDLK_UNKNOWN,
/* 3 */ SDLK_CANCEL, /* 3, 0x03 */ SDLK_CANCEL,
/* 4 */ SDLK_UNKNOWN, /* 4, 0x04 */ SDLK_UNKNOWN,
/* 5 */ SDLK_UNKNOWN, /* 5, 0x05 */ SDLK_UNKNOWN,
/* 6 */ SDLK_HELP, /* 6, 0x06 */ SDLK_HELP,
/* 7 */ SDLK_UNKNOWN, /* 7, 0x07 */ SDLK_UNKNOWN,
/* 8 */ SDLK_BACKSPACE, /* 8, 0x08 */ SDLK_BACKSPACE,
/* 9 */ SDLK_TAB, /* 9, 0x09 */ SDLK_TAB,
/* 10 */ SDLK_UNKNOWN, /* 10, 0x0a */ SDLK_UNKNOWN,
/* 11 */ SDLK_UNKNOWN, /* 11, 0x0b */ SDLK_UNKNOWN,
/* 12 */ SDLK_KP_5, /* 12, 0x0c */ SDLK_KP_EQUALS,
/* 13 */ SDLK_RETURN, /* 13, 0x0d */ SDLK_RETURN,
/* 14 */ SDLK_UNKNOWN, /* 14, 0x0e */ SDLK_UNKNOWN,
/* 15 */ SDLK_UNKNOWN, /* 15, 0x0f */ SDLK_UNKNOWN,
/* 16 */ SDLK_LSHIFT, /* 16, 0x10 */ SDLK_LSHIFT,
/* 17 */ SDLK_LCTRL, /* 17, 0x11 */ SDLK_LCTRL,
/* 18 */ SDLK_LALT, /* 18, 0x12 */ SDLK_LALT,
/* 19 */ SDLK_PAUSE, /* 19, 0x13 */ SDLK_PAUSE,
/* 20 */ SDLK_CAPSLOCK, /* 20, 0x14 */ SDLK_CAPSLOCK,
/* 21 */ SDLK_UNKNOWN, /* 21, 0x15 */ SDLK_UNKNOWN,
/* 22 */ SDLK_UNKNOWN, /* 22, 0x16 */ SDLK_UNKNOWN,
/* 23 */ SDLK_UNKNOWN, /* 23, 0x17 */ SDLK_UNKNOWN,
/* 24 */ SDLK_UNKNOWN, /* 24, 0x18 */ SDLK_UNKNOWN,
/* 25 */ SDLK_UNKNOWN, /* 25, 0x19 */ SDLK_UNKNOWN,
/* 26 */ SDLK_UNKNOWN, /* 26, 0x1a */ SDLK_UNKNOWN,
/* 27 */ SDLK_ESCAPE, /* 27, 0x1b */ SDLK_ESCAPE,
/* 28 */ SDLK_UNKNOWN, /* 28, 0x1c */ SDLK_UNKNOWN,
/* 29 */ SDLK_UNKNOWN, /* 29, 0x1d */ SDLK_UNKNOWN,
/* 30 */ SDLK_UNKNOWN, /* 30, 0x1e */ SDLK_UNKNOWN,
/* 31 */ SDLK_UNKNOWN, /* 31, 0x1f */ SDLK_UNKNOWN,
/* 32 */ SDLK_SPACE, /* 32, 0x20 */ SDLK_SPACE,
/* 33 */ SDLK_PAGEUP, /* 33, 0x21 */ SDLK_PAGEUP,
/* 34 */ SDLK_PAGEDOWN, /* 34, 0x22 */ SDLK_PAGEDOWN,
/* 35 */ SDLK_END, /* 35, 0x23 */ SDLK_END,
/* 36 */ SDLK_HOME, /* 36, 0x24 */ SDLK_HOME,
/* 37 */ SDLK_LEFT, /* 37, 0x25 */ SDLK_LEFT,
/* 38 */ SDLK_UP, /* 38, 0x26 */ SDLK_UP,
/* 39 */ SDLK_RIGHT, /* 39, 0x27 */ SDLK_RIGHT,
/* 40 */ SDLK_DOWN, /* 40, 0x28 */ SDLK_DOWN,
/* 41 */ SDLK_UNKNOWN, /* 41, 0x29 */ SDLK_UNKNOWN,
/* 42 */ SDLK_UNKNOWN, /* 42, 0x2a */ SDLK_UNKNOWN,
/* 43 */ SDLK_UNKNOWN, /* 43, 0x2b */ SDLK_UNKNOWN,
/* 44 */ SDLK_UNKNOWN, /* 44, 0x2c */ SDLK_UNKNOWN,
/* 45 */ SDLK_INSERT, /* 45, 0x2d */ SDLK_INSERT,
/* 46 */ SDLK_DELETE, /* 46, 0x2e */ SDLK_DELETE,
/* 47 */ SDLK_UNKNOWN, /* 47, 0x2f */ SDLK_UNKNOWN,
/* 48 */ SDLK_0, /* 48, 0x30 */ SDLK_0,
/* 49 */ SDLK_1, /* 49, 0x31 */ SDLK_1,
/* 50 */ SDLK_2, /* 50, 0x32 */ SDLK_2,
/* 51 */ SDLK_3, /* 51, 0x33 */ SDLK_3,
/* 52 */ SDLK_4, /* 52, 0x34 */ SDLK_4,
/* 53 */ SDLK_5, /* 53, 0x35 */ SDLK_5,
/* 54 */ SDLK_6, /* 54, 0x36 */ SDLK_6,
/* 55 */ SDLK_7, /* 55, 0x37 */ SDLK_7,
/* 56 */ SDLK_8, /* 56, 0x38 */ SDLK_8,
/* 57 */ SDLK_9, /* 57, 0x39 */ SDLK_9,
/* 58 */ SDLK_UNKNOWN, /* 58, 0x3a */ SDLK_UNKNOWN,
/* 59 */ SDLK_SEMICOLON, /* 59, 0x3b */ SDLK_SEMICOLON,
/* 60 */ SDLK_BACKSLASH /*SDL_SCANCODE_NONUSBACKSLASH*/, /* 60, 0x3c */ SDLK_BACKSLASH /*SDL_SCANCODE_NONUSBACKSLASH*/,
/* 61 */ SDLK_EQUALS, /* 61, 0x3d */ SDLK_EQUALS,
/* 62 */ SDLK_UNKNOWN, /* 62, 0x3e */ SDLK_UNKNOWN,
/* 63 */ SDLK_MINUS, /* 63, 0x3f */ SDLK_MINUS,
/* 64 */ SDLK_UNKNOWN, /* 64, 0x40 */ SDLK_UNKNOWN,
/* 65 */ SDLK_A, /* 65, 0x41 */ SDLK_A,
/* 66 */ SDLK_B, /* 66, 0x42 */ SDLK_B,
/* 67 */ SDLK_C, /* 67, 0x43 */ SDLK_C,
/* 68 */ SDLK_D, /* 68, 0x44 */ SDLK_D,
/* 69 */ SDLK_E, /* 69, 0x45 */ SDLK_E,
/* 70 */ SDLK_F, /* 70, 0x46 */ SDLK_F,
/* 71 */ SDLK_G, /* 71, 0x47 */ SDLK_G,
/* 72 */ SDLK_H, /* 72, 0x48 */ SDLK_H,
/* 73 */ SDLK_I, /* 73, 0x49 */ SDLK_I,
/* 74 */ SDLK_J, /* 74, 0x4a */ SDLK_J,
/* 75 */ SDLK_K, /* 75, 0x4b */ SDLK_K,
/* 76 */ SDLK_L, /* 76, 0x4c */ SDLK_L,
/* 77 */ SDLK_M, /* 77, 0x4d */ SDLK_M,
/* 78 */ SDLK_N, /* 78, 0x4e */ SDLK_N,
/* 79 */ SDLK_O, /* 79, 0x4f */ SDLK_O,
/* 80 */ SDLK_P, /* 80, 0x50 */ SDLK_P,
/* 81 */ SDLK_Q, /* 81, 0x51 */ SDLK_Q,
/* 82 */ SDLK_R, /* 82, 0x52 */ SDLK_R,
/* 83 */ SDLK_S, /* 83, 0x53 */ SDLK_S,
/* 84 */ SDLK_T, /* 84, 0x54 */ SDLK_T,
/* 85 */ SDLK_U, /* 85, 0x55 */ SDLK_U,
/* 86 */ SDLK_V, /* 86, 0x56 */ SDLK_V,
/* 87 */ SDLK_W, /* 87, 0x57 */ SDLK_W,
/* 88 */ SDLK_X, /* 88, 0x58 */ SDLK_X,
/* 89 */ SDLK_Y, /* 89, 0x59 */ SDLK_Y,
/* 90 */ SDLK_Z, /* 90, 0x5a */ SDLK_Z,
/* 91 */ SDLK_LGUI, /* 91, 0x5b */ SDLK_LGUI,
/* 92 */ SDLK_UNKNOWN, /* 92, 0x5c */ SDLK_UNKNOWN,
/* 93 */ SDLK_APPLICATION, /* 93, 0x5d */ SDLK_APPLICATION,
/* 94 */ SDLK_UNKNOWN, /* 94, 0x5e */ SDLK_UNKNOWN,
/* 95 */ SDLK_UNKNOWN, /* 95, 0x5f */ SDLK_UNKNOWN,
/* 96 */ SDLK_KP_0, /* 96, 0x60 */ SDLK_0, /* SDLK_KP_0 */
/* 97 */ SDLK_KP_1, /* 97, 0x61 */ SDLK_1, /* SDLK_KP_1 */
/* 98 */ SDLK_KP_2, /* 98, 0x62 */ SDLK_2, /* SDLK_KP_2 */
/* 99 */ SDLK_KP_3, /* 99, 0x63 */ SDLK_3, /* SDLK_KP_3 */
/* 100 */ SDLK_KP_4, /* 100, 0x64 */ SDLK_4, /* SDLK_KP_4 */
/* 101 */ SDLK_KP_5, /* 101, 0x65 */ SDLK_5, /* SDLK_KP_5 */
/* 102 */ SDLK_KP_6, /* 102, 0x66 */ SDLK_6, /* SDLK_KP_6 */
/* 103 */ SDLK_KP_7, /* 103, 0x67 */ SDLK_7, /* SDLK_KP_7 */
/* 104 */ SDLK_KP_8, /* 104, 0x68 */ SDLK_8, /* SDLK_KP_8 */
/* 105 */ SDLK_KP_9, /* 105, 0x69 */ SDLK_9, /* SDLK_KP_9 */
/* 106 */ SDLK_KP_MULTIPLY, /* 106, 0x6a */ SDLK_KP_MULTIPLY,
/* 107 */ SDLK_KP_PLUS, /* 107, 0x6b */ SDLK_KP_PLUS,
/* 108 */ SDLK_UNKNOWN, /* 108, 0x6c */ SDLK_UNKNOWN,
/* 109 */ SDLK_KP_MINUS, /* 109, 0x6d */ SDLK_KP_MINUS,
/* 110 */ SDLK_KP_PERIOD, /* 110, 0x6e */ SDLK_PERIOD, /* SDLK_KP_PERIOD */
/* 111 */ SDLK_KP_DIVIDE, /* 111, 0x6f */ SDLK_KP_DIVIDE,
/* 112 */ SDLK_F1, /* 112, 0x70 */ SDLK_F1,
/* 113 */ SDLK_F2, /* 113, 0x71 */ SDLK_F2,
/* 114 */ SDLK_F3, /* 114, 0x72 */ SDLK_F3,
/* 115 */ SDLK_F4, /* 115, 0x73 */ SDLK_F4,
/* 116 */ SDLK_F5, /* 116, 0x74 */ SDLK_F5,
/* 117 */ SDLK_F6, /* 117, 0x75 */ SDLK_F6,
/* 118 */ SDLK_F7, /* 118, 0x76 */ SDLK_F7,
/* 119 */ SDLK_F8, /* 119, 0x77 */ SDLK_F8,
/* 120 */ SDLK_F9, /* 120, 0x78 */ SDLK_F9,
/* 121 */ SDLK_F10, /* 121, 0x79 */ SDLK_F10,
/* 122 */ SDLK_F11, /* 122, 0x7a */ SDLK_F11,
/* 123 */ SDLK_F12, /* 123, 0x7b */ SDLK_F12,
/* 124 */ SDLK_F13, /* 124, 0x7c */ SDLK_F13,
/* 125 */ SDLK_F14, /* 125, 0x7d */ SDLK_F14,
/* 126 */ SDLK_F15, /* 126, 0x7e */ SDLK_F15,
/* 127 */ SDLK_F16, /* 127, 0x7f */ SDLK_F16,
/* 128 */ SDLK_F17, /* 128, 0x80 */ SDLK_F17,
/* 129 */ SDLK_F18, /* 129, 0x81 */ SDLK_F18,
/* 130 */ SDLK_F19, /* 130, 0x82 */ SDLK_F19,
/* 131 */ SDLK_F20, /* 131, 0x83 */ SDLK_F20,
/* 132 */ SDLK_F21, /* 132, 0x84 */ SDLK_F21,
/* 133 */ SDLK_F22, /* 133, 0x85 */ SDLK_F22,
/* 134 */ SDLK_F23, /* 134, 0x86 */ SDLK_F23,
/* 135 */ SDLK_F24, /* 135, 0x87 */ SDLK_F24,
/* 136 */ SDLK_UNKNOWN, /* 136, 0x88 */ SDLK_UNKNOWN,
/* 137 */ SDLK_UNKNOWN, /* 137, 0x89 */ SDLK_UNKNOWN,
/* 138 */ SDLK_UNKNOWN, /* 138, 0x8a */ SDLK_UNKNOWN,
/* 139 */ SDLK_UNKNOWN, /* 139, 0x8b */ SDLK_UNKNOWN,
/* 140 */ SDLK_UNKNOWN, /* 140, 0x8c */ SDLK_UNKNOWN,
/* 141 */ SDLK_UNKNOWN, /* 141, 0x8d */ SDLK_UNKNOWN,
/* 142 */ SDLK_UNKNOWN, /* 142, 0x8e */ SDLK_UNKNOWN,
/* 143 */ SDLK_UNKNOWN, /* 143, 0x8f */ SDLK_UNKNOWN,
/* 144 */ SDLK_NUMLOCKCLEAR, /* 144, 0x90 */ SDLK_NUMLOCKCLEAR,
/* 145 */ SDLK_SCROLLLOCK, /* 145, 0x91 */ SDLK_SCROLLLOCK,
/* 146 */ SDLK_UNKNOWN, /* 146, 0x92 */ SDLK_UNKNOWN,
/* 147 */ SDLK_UNKNOWN, /* 147, 0x93 */ SDLK_UNKNOWN,
/* 148 */ SDLK_UNKNOWN, /* 148, 0x94 */ SDLK_UNKNOWN,
/* 149 */ SDLK_UNKNOWN, /* 149, 0x95 */ SDLK_UNKNOWN,
/* 150 */ SDLK_UNKNOWN, /* 150, 0x96 */ SDLK_UNKNOWN,
/* 151 */ SDLK_UNKNOWN, /* 151, 0x97 */ SDLK_UNKNOWN,
/* 152 */ SDLK_UNKNOWN, /* 152, 0x98 */ SDLK_UNKNOWN,
/* 153 */ SDLK_UNKNOWN, /* 153, 0x99 */ SDLK_UNKNOWN,
/* 154 */ SDLK_UNKNOWN, /* 154, 0x9a */ SDLK_UNKNOWN,
/* 155 */ SDLK_UNKNOWN, /* 155, 0x9b */ SDLK_UNKNOWN,
/* 156 */ SDLK_UNKNOWN, /* 156, 0x9c */ SDLK_UNKNOWN,
/* 157 */ SDLK_UNKNOWN, /* 157, 0x9d */ SDLK_UNKNOWN,
/* 158 */ SDLK_UNKNOWN, /* 158, 0x9e */ SDLK_UNKNOWN,
/* 159 */ SDLK_UNKNOWN, /* 159, 0x9f */ SDLK_UNKNOWN,
/* 160 */ SDLK_GRAVE, /* 160, 0xa0 */ SDLK_GRAVE,
/* 161 */ SDLK_UNKNOWN, /* 161, 0xa1 */ SDLK_UNKNOWN,
/* 162 */ SDLK_UNKNOWN, /* 162, 0xa2 */ SDLK_UNKNOWN,
/* 163 */ SDLK_KP_HASH, /*KaiOS phone keypad*/ /* 163, 0xa3 */ SDLK_KP_HASH, /*KaiOS phone keypad*/
/* 164 */ SDLK_UNKNOWN, /* 164, 0xa4 */ SDLK_UNKNOWN,
/* 165 */ SDLK_UNKNOWN, /* 165, 0xa5 */ SDLK_UNKNOWN,
/* 166 */ SDLK_UNKNOWN, /* 166, 0xa6 */ SDLK_UNKNOWN,
/* 167 */ SDLK_UNKNOWN, /* 167, 0xa7 */ SDLK_UNKNOWN,
/* 168 */ SDLK_UNKNOWN, /* 168, 0xa8 */ SDLK_UNKNOWN,
/* 169 */ SDLK_UNKNOWN, /* 169, 0xa9 */ SDLK_UNKNOWN,
/* 170 */ SDLK_KP_MULTIPLY, /*KaiOS phone keypad*/ /* 170, 0xaa */ SDLK_KP_MULTIPLY, /*KaiOS phone keypad*/
/* 171 */ SDLK_RIGHTBRACKET, /* 171, 0xab */ SDLK_RIGHTBRACKET,
/* 172 */ SDLK_UNKNOWN, /* 172, 0xac */ SDLK_UNKNOWN,
/* 173 */ SDLK_MINUS, /*FX*/ /* 173, 0xad */ SDLK_MINUS, /*FX*/
/* 174 */ SDLK_VOLUMEDOWN, /*IE, Chrome*/ /* 174, 0xae */ SDLK_VOLUMEDOWN, /*IE, Chrome*/
/* 175 */ SDLK_VOLUMEUP, /*IE, Chrome*/ /* 175, 0xaf */ SDLK_VOLUMEUP, /*IE, Chrome*/
/* 176 */ SDLK_MEDIA_NEXT_TRACK, /*IE, Chrome*/ /* 176, 0xb0 */ SDLK_MEDIA_NEXT_TRACK, /*IE, Chrome*/
/* 177 */ SDLK_MEDIA_PREVIOUS_TRACK, /*IE, Chrome*/ /* 177, 0xb1 */ SDLK_MEDIA_PREVIOUS_TRACK, /*IE, Chrome*/
/* 178 */ SDLK_UNKNOWN, /* 178, 0xb2 */ SDLK_UNKNOWN,
/* 179 */ SDLK_MEDIA_PLAY, /*IE, Chrome*/ /* 179, 0xb3 */ SDLK_MEDIA_PLAY, /*IE, Chrome*/
/* 180 */ SDLK_UNKNOWN, /* 180, 0xb4 */ SDLK_UNKNOWN,
/* 181 */ SDLK_UNKNOWN, /* 181, 0xb5 */ SDLK_UNKNOWN,
/* 182 */ SDLK_VOLUMEDOWN, /*FX*/ /* 182, 0xb6 */ SDLK_VOLUMEDOWN, /*FX*/
/* 183 */ SDLK_VOLUMEUP, /*FX*/ /* 183, 0xb7 */ SDLK_VOLUMEUP, /*FX*/
/* 184 */ SDLK_UNKNOWN, /* 184, 0xb8 */ SDLK_UNKNOWN,
/* 185 */ SDLK_UNKNOWN, /* 185, 0xb9 */ SDLK_UNKNOWN,
/* 186 */ SDLK_SEMICOLON, /*IE, Chrome, D3E legacy*/ /* 186, 0xba */ SDLK_SEMICOLON, /*IE, Chrome, D3E legacy*/
/* 187 */ SDLK_EQUALS, /*IE, Chrome, D3E legacy*/ /* 187, 0xbb */ SDLK_EQUALS, /*IE, Chrome, D3E legacy*/
/* 188 */ SDLK_COMMA, /* 188, 0xbc */ SDLK_COMMA,
/* 189 */ SDLK_MINUS, /*IE, Chrome, D3E legacy*/ /* 189, 0xbd */ SDLK_MINUS, /*IE, Chrome, D3E legacy*/
/* 190 */ SDLK_PERIOD, /* 190, 0xbe */ SDLK_PERIOD,
/* 191 */ SDLK_SLASH, /* 191, 0xbf */ SDLK_SLASH,
/* 192 */ SDLK_GRAVE, /*FX, D3E legacy (SDLK_APOSTROPHE in IE/Chrome)*/ /* 192, 0xc0 */ SDLK_GRAVE, /*FX, D3E legacy (SDLK_APOSTROPHE in IE/Chrome)*/
/* 193 */ SDLK_UNKNOWN, /* 193, 0xc1 */ SDLK_UNKNOWN,
/* 194 */ SDLK_UNKNOWN, /* 194, 0xc2 */ SDLK_UNKNOWN,
/* 195 */ SDLK_UNKNOWN, /* 195, 0xc3 */ SDLK_UNKNOWN,
/* 196 */ SDLK_UNKNOWN, /* 196, 0xc4 */ SDLK_UNKNOWN,
/* 197 */ SDLK_UNKNOWN, /* 197, 0xc5 */ SDLK_UNKNOWN,
/* 198 */ SDLK_UNKNOWN, /* 198, 0xc6 */ SDLK_UNKNOWN,
/* 199 */ SDLK_UNKNOWN, /* 199, 0xc7 */ SDLK_UNKNOWN,
/* 200 */ SDLK_UNKNOWN, /* 200, 0xc8 */ SDLK_UNKNOWN,
/* 201 */ SDLK_UNKNOWN, /* 201, 0xc9 */ SDLK_UNKNOWN,
/* 202 */ SDLK_UNKNOWN, /* 202, 0xca */ SDLK_UNKNOWN,
/* 203 */ SDLK_UNKNOWN, /* 203, 0xcb */ SDLK_UNKNOWN,
/* 204 */ SDLK_UNKNOWN, /* 204, 0xcc */ SDLK_UNKNOWN,
/* 205 */ SDLK_UNKNOWN, /* 205, 0xcd */ SDLK_UNKNOWN,
/* 206 */ SDLK_UNKNOWN, /* 206, 0xce */ SDLK_UNKNOWN,
/* 207 */ SDLK_UNKNOWN, /* 207, 0xcf */ SDLK_UNKNOWN,
/* 208 */ SDLK_UNKNOWN, /* 208, 0xd0 */ SDLK_UNKNOWN,
/* 209 */ SDLK_UNKNOWN, /* 209, 0xd1 */ SDLK_UNKNOWN,
/* 210 */ SDLK_UNKNOWN, /* 210, 0xd2 */ SDLK_UNKNOWN,
/* 211 */ SDLK_UNKNOWN, /* 211, 0xd3 */ SDLK_UNKNOWN,
/* 212 */ SDLK_UNKNOWN, /* 212, 0xd4 */ SDLK_UNKNOWN,
/* 213 */ SDLK_UNKNOWN, /* 213, 0xd5 */ SDLK_UNKNOWN,
/* 214 */ SDLK_UNKNOWN, /* 214, 0xd6 */ SDLK_UNKNOWN,
/* 215 */ SDLK_UNKNOWN, /* 215, 0xd7 */ SDLK_UNKNOWN,
/* 216 */ SDLK_UNKNOWN, /* 216, 0xd8 */ SDLK_UNKNOWN,
/* 217 */ SDLK_UNKNOWN, /* 217, 0xd9 */ SDLK_UNKNOWN,
/* 218 */ SDLK_UNKNOWN, /* 218, 0xda */ SDLK_UNKNOWN,
/* 219 */ SDLK_LEFTBRACKET, /* 219, 0xdb */ SDLK_LEFTBRACKET,
/* 220 */ SDLK_BACKSLASH, /* 220, 0xdc */ SDLK_BACKSLASH,
/* 221 */ SDLK_RIGHTBRACKET, /* 221, 0xdd */ SDLK_RIGHTBRACKET,
/* 222 */ SDLK_APOSTROPHE, /*FX, D3E legacy*/ /* 222, 0xde */ SDLK_APOSTROPHE, /*FX, D3E legacy*/
}; };
/* /*
@ -513,56 +513,6 @@ static SDL_Keycode Emscripten_MapKeyCode(const EmscriptenKeyboardEvent *keyEvent
default: default:
break; break;
} }
} else if (keyEvent->location == DOM_KEY_LOCATION_NUMPAD) {
switch (keycode) {
case SDLK_0:
case SDLK_INSERT:
keycode = SDLK_KP_0;
break;
case SDLK_1:
case SDLK_END:
keycode = SDLK_KP_1;
break;
case SDLK_2:
case SDLK_DOWN:
keycode = SDLK_KP_2;
break;
case SDLK_3:
case SDLK_PAGEDOWN:
keycode = SDLK_KP_3;
break;
case SDLK_4:
case SDLK_LEFT:
keycode = SDLK_KP_4;
break;
case SDLK_5:
keycode = SDLK_KP_5;
break;
case SDLK_6:
case SDLK_RIGHT:
keycode = SDLK_KP_6;
break;
case SDLK_7:
case SDLK_HOME:
keycode = SDLK_KP_7;
break;
case SDLK_8:
case SDLK_UP:
keycode = SDLK_KP_8;
break;
case SDLK_9:
case SDLK_PAGEUP:
keycode = SDLK_KP_9;
break;
case SDLK_RETURN:
keycode = SDLK_KP_ENTER;
break;
case SDLK_DELETE:
keycode = SDLK_KP_PERIOD;
break;
default:
break;
}
} }
} }
} }

View file

@ -1109,7 +1109,7 @@ static void Wayland_keymap_iter(struct xkb_keymap *keymap, xkb_keycode_t key, vo
/* Note: The default SDL scancode table sets this to right alt instead of AltGr/Mode, so handle it separately. */ /* Note: The default SDL scancode table sets this to right alt instead of AltGr/Mode, so handle it separately. */
if (syms[0] != XKB_KEY_ISO_Level3_Shift) { if (syms[0] != XKB_KEY_ISO_Level3_Shift) {
keycode = SDL_GetDefaultKeyFromScancode(sc, SDL_KMOD_NONE); keycode = SDL_GetDefaultKeyFromScancode(sc, sdlKeymap->modstate);
} else { } else {
keycode = SDLK_MODE; keycode = SDLK_MODE;
} }

View file

@ -106,13 +106,7 @@ void WIN_UpdateKeymap(SDL_bool send_event)
/* Make sure this scancode is a valid character scancode */ /* Make sure this scancode is a valid character scancode */
scancode = windows_scancode_table[i]; scancode = windows_scancode_table[i];
if (scancode == SDL_SCANCODE_UNKNOWN || if (scancode == SDL_SCANCODE_UNKNOWN ||
(SDL_GetDefaultKeyFromScancode(scancode, SDL_KMOD_NONE) & SDLK_SCANCODE_MASK)) { scancode >= SDL_SCANCODE_CAPSLOCK) {
continue;
}
/* If this key is one of the non-mappable keys, ignore it */
/* Uncomment the second part to re-enable the behavior of not mapping the "`"(grave) key to the users actual keyboard layout */
if (scancode == SDL_SCANCODE_DELETE /*|| scancode == SDL_SCANCODE_GRAVE*/) {
continue; continue;
} }

View file

@ -382,30 +382,7 @@ void X11_UpdateKeymap(SDL_VideoDevice *_this, SDL_bool send_event)
if (!keycode) { if (!keycode) {
SDL_Scancode keyScancode = SDL_GetScancodeFromKeySym(keysym, (KeyCode)i); SDL_Scancode keyScancode = SDL_GetScancodeFromKeySym(keysym, (KeyCode)i);
keycode = SDL_GetDefaultKeyFromScancode(keyScancode, keymod_masks[m].sdl_mask);
switch (keyScancode) {
case SDL_SCANCODE_UNKNOWN:
keycode = SDLK_UNKNOWN;
break;
case SDL_SCANCODE_RETURN:
keycode = SDLK_RETURN;
break;
case SDL_SCANCODE_ESCAPE:
keycode = SDLK_ESCAPE;
break;
case SDL_SCANCODE_BACKSPACE:
keycode = SDLK_BACKSPACE;
break;
case SDL_SCANCODE_TAB:
keycode = SDLK_TAB;
break;
case SDL_SCANCODE_DELETE:
keycode = SDLK_DELETE;
break;
default:
keycode = SDL_SCANCODE_TO_KEYCODE(keyScancode);
break;
}
} }
SDL_SetKeymapEntry(keymap, scancode, keymod_masks[m].sdl_mask, keycode); SDL_SetKeymapEntry(keymap, scancode, keymod_masks[m].sdl_mask, keycode);
} }