aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/mgl/window/event.h12
-rw-r--r--include/mgl/window/key.h9
-rw-r--r--meson.build1
-rw-r--r--src/window/key.c167
-rw-r--r--src/window/window.c67
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: {