Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Rauch <christian.rauch>2020-05-06 03:20:32 +0300
committerCampbell Barton <ideasman42@gmail.com>2020-05-06 03:20:32 +0300
commit4af9578ab794b10ea6742db0dc8d528646beee07 (patch)
tree063b28643a977662af39b759a987a127bdac3bc2 /intern/ghost
parentb0d6b03763243801922405e738049f34e961ecd5 (diff)
Fix T76429: GHOST/Wayland event's don't correspond to physical keys
Diffstat (limited to 'intern/ghost')
-rw-r--r--intern/ghost/intern/GHOST_SystemWayland.cpp20
1 files changed, 18 insertions, 2 deletions
diff --git a/intern/ghost/intern/GHOST_SystemWayland.cpp b/intern/ghost/intern/GHOST_SystemWayland.cpp
index 666515ed088..d0c29efad16 100644
--- a/intern/ghost/intern/GHOST_SystemWayland.cpp
+++ b/intern/ghost/intern/GHOST_SystemWayland.cpp
@@ -330,7 +330,8 @@ static GHOST_TKey xkb_map_gkey(const xkb_keysym_t &sym)
GXMAP(gkey, XKB_KEY_XF86AudioPrev, GHOST_kKeyMediaFirst);
GXMAP(gkey, XKB_KEY_XF86AudioNext, GHOST_kKeyMediaLast);
default:
- GHOST_PRINT("unhandled key: " << sym << std::endl);
+ GHOST_PRINT("unhandled key: " << std::hex << std::showbase << sym << std::dec << " ("
+ << sym << ")" << std::endl);
gkey = GHOST_kKeyUnknown;
}
#undef GXMAP
@@ -942,6 +943,20 @@ static void keyboard_leave(void * /*data*/,
/* pass */
}
+/**
+ * A version of #xkb_state_key_get_one_sym which returns the key without any modifiers pressed.
+ * Needed because #GHOST_TKey uses these values as key-codes.
+ */
+static xkb_keysym_t xkb_state_key_get_one_sym_without_modifiers(struct xkb_state *xkb_state,
+ xkb_keycode_t key)
+{
+ /* Use an empty keyboard state to access key symbol without modifiers. */
+ struct xkb_state *xkb_state_empty = xkb_state_new(xkb_state_get_keymap(xkb_state));
+ const xkb_keysym_t sym = xkb_state_key_get_one_sym(xkb_state_empty, key);
+ xkb_state_unref(xkb_state_empty);
+ return sym;
+}
+
static void keyboard_key(void *data,
struct wl_keyboard * /*wl_keyboard*/,
uint32_t serial,
@@ -961,7 +976,8 @@ static void keyboard_key(void *data,
break;
}
- const xkb_keysym_t sym = xkb_state_key_get_one_sym(input->xkb_state, key + 8);
+ const xkb_keysym_t sym = xkb_state_key_get_one_sym_without_modifiers(input->xkb_state, key + 8);
+
if (sym == XKB_KEY_NoSymbol) {
return;
}