diff options
-rw-r--r-- | include/mgl/window/event.h | 12 | ||||
-rw-r--r-- | include/mgl/window/key.h | 9 | ||||
-rw-r--r-- | meson.build | 1 | ||||
-rw-r--r-- | src/window/key.c | 167 | ||||
-rw-r--r-- | src/window/window.c | 67 |
5 files changed, 202 insertions, 54 deletions
diff --git a/include/mgl/window/event.h b/include/mgl/window/event.h index 4813154..0f0d94e 100644 --- a/include/mgl/window/event.h +++ b/include/mgl/window/event.h @@ -60,6 +60,16 @@ typedef struct { } mgl_monitor_disconnected_event; typedef enum { + MGL_MAPPING_CHANGED_MODIFIER, + MGL_MAPPING_CHANGED_KEYBOARD, + MGL_MAPPING_CHANGED_POINTER +} mgl_mapping_changed_type; + +typedef struct { + int type; /* mgl_mapping_changed_type */ +} mgl_mapping_changed_event; + +typedef enum { MGL_EVENT_UNKNOWN, MGL_EVENT_CLOSED, /* Window closed */ MGL_EVENT_RESIZED, /* Window resized */ @@ -75,6 +85,7 @@ typedef enum { MGL_EVENT_MONITOR_CONNECTED, MGL_EVENT_MONITOR_DISCONNECTED, MGL_EVENT_MONITOR_PROPERTY_CHANGED, + MGL_EVENT_MAPPING_CHANGED } mgl_event_type; struct mgl_event { @@ -89,6 +100,7 @@ struct mgl_event { mgl_monitor_connected_event monitor_connected; mgl_monitor_disconnected_event monitor_disconnected; mgl_monitor_property_changed_event monitor_property_changed; + mgl_mapping_changed_event mapping_changed; }; }; diff --git a/include/mgl/window/key.h b/include/mgl/window/key.h index 0cd3c03..3f3976b 100644 --- a/include/mgl/window/key.h +++ b/include/mgl/window/key.h @@ -1,6 +1,9 @@ #ifndef _MGL_KEY_H_ #define _MGL_KEY_H_ +#include <stdbool.h> +#include <stdint.h> + typedef enum { MGL_KEY_UNKNOWN, MGL_KEY_A, @@ -109,4 +112,10 @@ typedef enum { __MGL_NUM_KEYS__ } mgl_key; +/* Return NULL if unknown key */ +const char* mgl_key_to_string(mgl_key key); +bool mgl_key_is_modifier(mgl_key key); +/* Returns XK_VoidSymbol on no match */ +uint64_t mgl_key_to_x11_keysym(mgl_key key); + #endif /* _MGL_KEY_H_ */ diff --git a/meson.build b/meson.build index 5cece60..7369b48 100644 --- a/meson.build +++ b/meson.build @@ -23,6 +23,7 @@ src = [ 'src/system/clock.c', 'src/mgl.c', 'src/window/window.c', + 'src/window/key.c', 'src/gl.c', ] diff --git a/src/window/key.c b/src/window/key.c new file mode 100644 index 0000000..ecddf0e --- /dev/null +++ b/src/window/key.c @@ -0,0 +1,167 @@ +#include "../../include/mgl/window/key.h" +#include <X11/keysym.h> + +const char* mgl_key_to_string(mgl_key key) { + switch(key) { + case MGL_KEY_UNKNOWN: return 0; + case MGL_KEY_A: return "A"; + case MGL_KEY_B: return "B"; + case MGL_KEY_C: return "C"; + case MGL_KEY_D: return "D"; + case MGL_KEY_E: return "E"; + case MGL_KEY_F: return "F"; + case MGL_KEY_G: return "G"; + case MGL_KEY_H: return "H"; + case MGL_KEY_I: return "I"; + case MGL_KEY_J: return "J"; + case MGL_KEY_K: return "K"; + case MGL_KEY_L: return "L"; + case MGL_KEY_M: return "M"; + case MGL_KEY_N: return "N"; + case MGL_KEY_O: return "O"; + case MGL_KEY_P: return "P"; + case MGL_KEY_Q: return "Q"; + case MGL_KEY_R: return "R"; + case MGL_KEY_S: return "S"; + case MGL_KEY_T: return "T"; + case MGL_KEY_U: return "U"; + case MGL_KEY_V: return "V"; + case MGL_KEY_W: return "W"; + case MGL_KEY_X: return "X"; + case MGL_KEY_Y: return "Y"; + case MGL_KEY_Z: return "Z"; + case MGL_KEY_NUM0: return "0"; + case MGL_KEY_NUM1: return "1"; + case MGL_KEY_NUM2: return "2"; + case MGL_KEY_NUM3: return "3"; + case MGL_KEY_NUM4: return "4"; + case MGL_KEY_NUM5: return "5"; + case MGL_KEY_NUM6: return "6"; + case MGL_KEY_NUM7: return "7"; + case MGL_KEY_NUM8: return "8"; + case MGL_KEY_NUM9: return "9"; + case MGL_KEY_ESCAPE: return "Escape"; + case MGL_KEY_LCONTROL: return "Left ctrl"; + case MGL_KEY_LSHIFT: return "Left shift"; + case MGL_KEY_LALT: return "Left alt"; + case MGL_KEY_LSYSTEM: return "Left system"; + case MGL_KEY_RCONTROL: return "Right ctrl"; + case MGL_KEY_RSHIFT: return "Right shift"; + case MGL_KEY_RALT: return "Right alt"; + case MGL_KEY_RSYSTEM: return "Right system"; + case MGL_KEY_MENU: return "Menu"; + case MGL_KEY_LBRACKET: return "["; + case MGL_KEY_RBRACKET: return "]"; + case MGL_KEY_SEMICOLON: return ";"; + case MGL_KEY_COMMA: return ","; + case MGL_KEY_PERIOD: return "."; + case MGL_KEY_QUOTE: return "'"; + case MGL_KEY_SLASH: return "/"; + case MGL_KEY_BACKSLASH: return "\\"; + case MGL_KEY_TILDE: return "~"; + case MGL_KEY_EQUAL: return "="; + case MGL_KEY_HYPHEN: return "-"; + case MGL_KEY_SPACE: return "Space"; + case MGL_KEY_ENTER: return "Enter"; + case MGL_KEY_BACKSPACE: return "Backspace"; + case MGL_KEY_TAB: return "Tab"; + case MGL_KEY_PAGEUP: return "PageUp"; + case MGL_KEY_PAGEDOWN: return "PageDown"; + case MGL_KEY_END: return "End"; + case MGL_KEY_HOME: return "Home"; + case MGL_KEY_INSERT: return "Insert"; + case MGL_KEY_DELETE: return "Delete"; + case MGL_KEY_ADD: return "Add"; + case MGL_KEY_SUBTRACT: return "Subtract"; + case MGL_KEY_MULTIPLY: return "Multiply"; + case MGL_KEY_DIVIDE: return "Divide"; + case MGL_KEY_LEFT: return "Left"; + case MGL_KEY_RIGHT: return "Right"; + case MGL_KEY_UP: return "Up"; + case MGL_KEY_DOWN: return "Down"; + case MGL_KEY_NUMPAD0: return "Numpad0"; + case MGL_KEY_NUMPAD1: return "Numpad1"; + case MGL_KEY_NUMPAD2: return "Numpad2"; + case MGL_KEY_NUMPAD3: return "Numpad3"; + case MGL_KEY_NUMPAD4: return "Numpad4"; + case MGL_KEY_NUMPAD5: return "Numpad5"; + case MGL_KEY_NUMPAD6: return "Numpad6"; + case MGL_KEY_NUMPAD7: return "Numpad7"; + case MGL_KEY_NUMPAD8: return "Numpad8"; + case MGL_KEY_NUMPAD9: return "Numpad9"; + case MGL_KEY_F1: return "F1"; + case MGL_KEY_F2: return "F2"; + case MGL_KEY_F3: return "F3"; + case MGL_KEY_F4: return "F4"; + case MGL_KEY_F5: return "F5"; + case MGL_KEY_F6: return "F6"; + case MGL_KEY_F7: return "F7"; + case MGL_KEY_F8: return "F8"; + case MGL_KEY_F9: return "F9"; + case MGL_KEY_F10: return "F10"; + case MGL_KEY_F11: return "F11"; + case MGL_KEY_F12: return "F12"; + case MGL_KEY_F13: return "F13"; + case MGL_KEY_F14: return "F14"; + case MGL_KEY_F15: return "F15"; + case MGL_KEY_PAUSE: return "Pause"; + case __MGL_NUM_KEYS__: return 0; + } + return 0; +} + +bool mgl_key_is_modifier(mgl_key key) { + return key >= MGL_KEY_LCONTROL && key <= MGL_KEY_RSYSTEM; +} + +uint64_t mgl_key_to_x11_keysym(mgl_key key) { + if(key >= MGL_KEY_A && key <= MGL_KEY_Z) + return XK_A + (key - MGL_KEY_A); + if(key >= MGL_KEY_NUM0 && key <= MGL_KEY_NUM9) + return XK_0 + (key - MGL_KEY_NUM0); + if(key >= MGL_KEY_NUMPAD0 && key <= MGL_KEY_NUMPAD9) + return XK_KP_0 + (key - MGL_KEY_NUMPAD0); + + /* TODO: Fill in the rest */ + switch(key) { + case MGL_KEY_SPACE: return XK_space; + case MGL_KEY_BACKSPACE: return XK_BackSpace; + case MGL_KEY_TAB: return XK_Tab; + case MGL_KEY_ENTER: return XK_Return; + case MGL_KEY_ESCAPE: return XK_Escape; + case MGL_KEY_LCONTROL: return XK_Control_L; + case MGL_KEY_LSHIFT: return XK_Shift_L; + case MGL_KEY_LALT: return XK_Alt_L; + case MGL_KEY_LSYSTEM: return XK_Super_L; + case MGL_KEY_RCONTROL: return XK_Control_R; + case MGL_KEY_RSHIFT: return XK_Shift_R; + case MGL_KEY_RALT: return XK_Alt_R; + case MGL_KEY_RSYSTEM: return XK_Super_R; + case MGL_KEY_DELETE: return XK_Delete; + case MGL_KEY_HOME: return XK_Home; + case MGL_KEY_LEFT: return XK_Left; + case MGL_KEY_UP: return XK_Up; + case MGL_KEY_RIGHT: return XK_Right; + case MGL_KEY_DOWN: return XK_Down; + case MGL_KEY_PAGEUP: return XK_Page_Up; + case MGL_KEY_PAGEDOWN: return XK_Page_Down; + case MGL_KEY_END: return XK_End; + case MGL_KEY_F1: return XK_F1; + case MGL_KEY_F2: return XK_F2; + case MGL_KEY_F3: return XK_F3; + case MGL_KEY_F4: return XK_F4; + case MGL_KEY_F5: return XK_F5; + case MGL_KEY_F6: return XK_F6; + case MGL_KEY_F7: return XK_F7; + case MGL_KEY_F8: return XK_F8; + case MGL_KEY_F9: return XK_F9; + case MGL_KEY_F10: return XK_F10; + case MGL_KEY_F11: return XK_F11; + case MGL_KEY_F12: return XK_F12; + case MGL_KEY_F13: return XK_F13; + case MGL_KEY_F14: return XK_F14; + case MGL_KEY_F15: return XK_F15; + default: return XK_VoidSymbol; + } + return XK_VoidSymbol; +} diff --git a/src/window/window.c b/src/window/window.c index 485e400..9280e32 100644 --- a/src/window/window.c +++ b/src/window/window.c @@ -1140,59 +1140,6 @@ static mgl_key x11_keysym_to_mgl_key(KeySym key_sym) { return MGL_KEY_UNKNOWN; } -/* Returns XK_VoidSymbol on no match */ -static KeySym mgl_key_to_x11_keysym(mgl_key key) { - if(key >= MGL_KEY_A && key <= MGL_KEY_Z) - return XK_A + (key - MGL_KEY_A); - if(key >= MGL_KEY_NUM0 && key <= MGL_KEY_NUM9) - return XK_0 + (key - MGL_KEY_NUM0); - if(key >= MGL_KEY_NUMPAD0 && key <= MGL_KEY_NUMPAD9) - return XK_KP_0 + (key - MGL_KEY_NUMPAD0); - - /* TODO: Fill in the rest */ - switch(key) { - case MGL_KEY_SPACE: return XK_space; - case MGL_KEY_BACKSPACE: return XK_BackSpace; - case MGL_KEY_TAB: return XK_Tab; - case MGL_KEY_ENTER: return XK_Return; - case MGL_KEY_ESCAPE: return XK_Escape; - case MGL_KEY_LCONTROL: return XK_Control_L; - case MGL_KEY_LSHIFT: return XK_Shift_L; - case MGL_KEY_LALT: return XK_Alt_L; - case MGL_KEY_LSYSTEM: return XK_Super_L; - case MGL_KEY_RCONTROL: return XK_Control_R; - case MGL_KEY_RSHIFT: return XK_Shift_R; - case MGL_KEY_RALT: return XK_Alt_R; - case MGL_KEY_RSYSTEM: return XK_Super_R; - case MGL_KEY_DELETE: return XK_Delete; - case MGL_KEY_HOME: return XK_Home; - case MGL_KEY_LEFT: return XK_Left; - case MGL_KEY_UP: return XK_Up; - case MGL_KEY_RIGHT: return XK_Right; - case MGL_KEY_DOWN: return XK_Down; - case MGL_KEY_PAGEUP: return XK_Page_Up; - case MGL_KEY_PAGEDOWN: return XK_Page_Down; - case MGL_KEY_END: return XK_End; - case MGL_KEY_F1: return XK_F1; - case MGL_KEY_F2: return XK_F2; - case MGL_KEY_F3: return XK_F3; - case MGL_KEY_F4: return XK_F4; - case MGL_KEY_F5: return XK_F5; - case MGL_KEY_F6: return XK_F6; - case MGL_KEY_F7: return XK_F7; - case MGL_KEY_F8: return XK_F8; - case MGL_KEY_F9: return XK_F9; - case MGL_KEY_F10: return XK_F10; - case MGL_KEY_F11: return XK_F11; - case MGL_KEY_F12: return XK_F12; - case MGL_KEY_F13: return XK_F13; - case MGL_KEY_F14: return XK_F14; - case MGL_KEY_F15: return XK_F15; - default: return XK_VoidSymbol; - } - return XK_VoidSymbol; -} - static mgl_mouse_button x11_button_to_mgl_button(unsigned int button) { switch(button) { case Button1: return MGL_BUTTON_LEFT; @@ -1566,7 +1513,19 @@ static void mgl_window_on_receive_event(mgl_window *self, XEvent *xev, mgl_event } case MappingNotify: { XRefreshKeyboardMapping(&xev->xmapping); - event->type = MGL_EVENT_UNKNOWN; + event->type = MGL_EVENT_MAPPING_CHANGED; + event->mapping_changed.type = MappingModifier; + switch(xev->xmapping.request) { + case MappingModifier: + event->mapping_changed.type = MGL_MAPPING_CHANGED_MODIFIER; + break; + case MappingKeyboard: + event->mapping_changed.type = MGL_MAPPING_CHANGED_KEYBOARD; + break; + case MappingPointer: + event->mapping_changed.type = MGL_MAPPING_CHANGED_POINTER; + break; + } break; } default: { |