From: Daniel Stone Date: Wed, 30 May 2012 15:31:47 +0000 (+0100) Subject: wl_keyboard: Add modifier event X-Git-Tag: 0.94.90~28 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=9a1705c5f5e877d4e68bd0e7eb858f517375ba3f;p=profile%2Fivi%2Fwayland.git wl_keyboard: Add modifier event This event sends the current keyboard modifier/group state from the compositor to the client, allowing all clients to have a consistent view of the keyboard state (e.g. current layout, Caps Lock, et al). It should be sent after a keyboard enter event, and also immediately after any key event which changes the modifier state. Signed-off-by: Daniel Stone --- diff --git a/protocol/wayland.xml b/protocol/wayland.xml index 3979d97..eb09849 100644 --- a/protocol/wayland.xml +++ b/protocol/wayland.xml @@ -872,6 +872,19 @@ + + + + Notifies clients that the modifier and/or group state has + changed, and it should update its local state. + + + + + + + + diff --git a/src/wayland-server.c b/src/wayland-server.c index d4a70cf..323d32d 100644 --- a/src/wayland-server.c +++ b/src/wayland-server.c @@ -532,9 +532,26 @@ default_grab_key(struct wl_keyboard_grab *grab, } } +static void +default_grab_modifiers(struct wl_keyboard_grab *grab, uint32_t serial, + uint32_t mods_depressed, uint32_t mods_latched, + uint32_t mods_locked, uint32_t group) +{ + struct wl_keyboard *keyboard = grab->keyboard; + struct wl_resource *resource; + + resource = keyboard->focus_resource; + if (!resource) + return; + + wl_keyboard_send_modifiers(resource, serial, mods_depressed, + mods_latched, mods_locked, group); +} + static const struct wl_keyboard_grab_interface default_keyboard_grab_interface = { - default_grab_key + default_grab_key, + default_grab_modifiers, }; WL_EXPORT void diff --git a/src/wayland-server.h b/src/wayland-server.h index b1962ea..266b457 100644 --- a/src/wayland-server.h +++ b/src/wayland-server.h @@ -210,6 +210,9 @@ struct wl_keyboard_grab; struct wl_keyboard_grab_interface { void (*key)(struct wl_keyboard_grab *grab, uint32_t time, uint32_t key, uint32_t state); + void (*modifiers)(struct wl_keyboard_grab *grab, uint32_t serial, + uint32_t mods_depressed, uint32_t mods_latched, + uint32_t mods_locked, uint32_t group); }; struct wl_keyboard_grab {