summaryrefslogtreecommitdiff
path: root/gdk/wayland/gdkdevice-wayland.c
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2021-03-15 12:34:23 -0400
committerMatthias Clasen <mclasen@redhat.com>2021-03-15 12:34:23 -0400
commit1eebf0ebd1bd18bc67235eac98a578528d28867c (patch)
tree1c2be9cd6b7bf3cfac31415da527cd170c15a92f /gdk/wayland/gdkdevice-wayland.c
parent3daad8fe87c2ba05b8a3b6a530ad213d7b418a33 (diff)
downloadgtk+-1eebf0ebd1bd18bc67235eac98a578528d28867c.tar.gz
wayland: Emit keys-changed on layout changes
We were forgetting to do this in when layout changes are communicated via handle_modifiers.
Diffstat (limited to 'gdk/wayland/gdkdevice-wayland.c')
-rw-r--r--gdk/wayland/gdkdevice-wayland.c53
1 files changed, 37 insertions, 16 deletions
diff --git a/gdk/wayland/gdkdevice-wayland.c b/gdk/wayland/gdkdevice-wayland.c
index 712fcd2a98..0d13910a24 100644
--- a/gdk/wayland/gdkdevice-wayland.c
+++ b/gdk/wayland/gdkdevice-wayland.c
@@ -2197,6 +2197,24 @@ keyboard_handle_key (void *data,
}
+static int
+get_active_layout (GdkKeymap *keymap)
+{
+ struct xkb_keymap *xkb_keymap;
+ struct xkb_state *xkb_state;
+
+ xkb_keymap = _gdk_wayland_keymap_get_xkb_keymap (keymap);
+ xkb_state = _gdk_wayland_keymap_get_xkb_state (keymap);
+
+ for (int i = 0; i < xkb_keymap_num_layouts (xkb_keymap); i++)
+ {
+ if (xkb_state_layout_index_is_active (xkb_state, i, XKB_STATE_LAYOUT_EFFECTIVE))
+ return i;
+ }
+
+ return -1;
+}
+
static void
keyboard_handle_modifiers (void *data,
struct wl_keyboard *keyboard,
@@ -2215,17 +2233,18 @@ keyboard_handle_modifiers (void *data,
gboolean num_lock;
gboolean scroll_lock;
GdkModifierType modifiers;
+ int layout;
keymap = seat->keymap;
xkb_state = _gdk_wayland_keymap_get_xkb_state (keymap);
- direction = gdk_keymap_get_direction (seat->keymap);
- bidi = gdk_keymap_have_bidi_layouts (seat->keymap);
- caps_lock = gdk_keymap_get_caps_lock_state (seat->keymap);
- num_lock = gdk_keymap_get_num_lock_state (seat->keymap);
- scroll_lock = gdk_keymap_get_scroll_lock_state (seat->keymap);
- modifiers = gdk_keymap_get_modifier_state (seat->keymap);
-
+ direction = gdk_keymap_get_direction (keymap);
+ bidi = gdk_keymap_have_bidi_layouts (keymap);
+ caps_lock = gdk_keymap_get_caps_lock_state (keymap);
+ num_lock = gdk_keymap_get_num_lock_state (keymap);
+ scroll_lock = gdk_keymap_get_scroll_lock_state (keymap);
+ modifiers = gdk_keymap_get_modifier_state (keymap);
+ layout = get_active_layout (keymap);
/* Note: the docs for xkb_state_update mask state that all parameters
* must be passed, or we may end up with an 'incoherent' state. But the
@@ -2247,20 +2266,22 @@ keyboard_handle_modifiers (void *data,
seat->key_modifiers = gdk_keymap_get_modifier_state (keymap);
g_signal_emit_by_name (keymap, "state-changed");
+ if (layout != get_active_layout (keymap))
+ g_signal_emit_by_name (keymap, "keys-changed");
if (direction != gdk_keymap_get_direction (keymap))
- g_signal_emit_by_name (keymap, "direction-changed");
-
- if (direction != gdk_keymap_get_direction (seat->keymap))
- g_object_notify (G_OBJECT (seat->logical_keyboard), "direction");
- if (bidi != gdk_keymap_have_bidi_layouts (seat->keymap))
+ {
+ g_signal_emit_by_name (keymap, "direction-changed");
+ g_object_notify (G_OBJECT (seat->logical_keyboard), "direction");
+ }
+ if (bidi != gdk_keymap_have_bidi_layouts (keymap))
g_object_notify (G_OBJECT (seat->logical_keyboard), "has-bidi-layouts");
- if (caps_lock != gdk_keymap_get_caps_lock_state (seat->keymap))
+ if (caps_lock != gdk_keymap_get_caps_lock_state (keymap))
g_object_notify (G_OBJECT (seat->logical_keyboard), "caps-lock-state");
- if (num_lock != gdk_keymap_get_num_lock_state (seat->keymap))
+ if (num_lock != gdk_keymap_get_num_lock_state (keymap))
g_object_notify (G_OBJECT (seat->logical_keyboard), "num-lock-state");
- if (scroll_lock != gdk_keymap_get_scroll_lock_state (seat->keymap))
+ if (scroll_lock != gdk_keymap_get_scroll_lock_state (keymap))
g_object_notify (G_OBJECT (seat->logical_keyboard), "scroll-lock-state");
- if (modifiers != gdk_keymap_get_modifier_state (seat->keymap))
+ if (modifiers != gdk_keymap_get_modifier_state (keymap))
g_object_notify (G_OBJECT (seat->logical_keyboard), "modifier-state");
}