Browse Source

Bugfix: update the initial keyboard modifier state (Thanks lee, Ran)

This should make the numpad work correctly.
master
Michael Stapelberg 11 years ago
parent
commit
2f17b73e20
  1. 20
      i3lock.c

20
i3lock.c

@ -1,7 +1,7 @@
/* /*
* vim:ts=4:sw=4:expandtab * vim:ts=4:sw=4:expandtab
* *
* © 2010-2012 Michael Stapelberg * © 2010-2013 Michael Stapelberg
* *
* See LICENSE for licensing information * See LICENSE for licensing information
* *
@ -81,6 +81,9 @@ void u8_dec(char *s, int *i) {
* Ideally, xkbcommon would ship something like this itself, but as of now * Ideally, xkbcommon would ship something like this itself, but as of now
* (version 0.2.0), it doesnt. * (version 0.2.0), it doesnt.
* *
* TODO: Once xcb-xkb is enabled by default and released, we should port this
* code to xcb-xkb. See also https://github.com/xkbcommon/libxkbcommon/issues/1
*
*/ */
static bool load_keymap(void) { static bool load_keymap(void) {
bool ret = false; bool ret = false;
@ -127,6 +130,16 @@ static bool load_keymap(void) {
goto out; goto out;
} }
/* Get the initial modifier state to be in sync with the X server.
* See https://github.com/xkbcommon/libxkbcommon/issues/1 for why we ignore
* the base and latched fields. */
XkbStateRec state_rec;
XkbGetState(display, XkbUseCoreKbd, &state_rec);
xkb_state_update_mask(new_state,
0, 0, state_rec.locked_mods,
0, 0, state_rec.locked_group);
if (xkb_state != NULL) if (xkb_state != NULL)
xkb_state_unref(xkb_state); xkb_state_unref(xkb_state);
xkb_state = new_state; xkb_state = new_state;
@ -682,6 +695,11 @@ int main(int argc, char *argv[]) {
cursor = create_cursor(conn, screen, win, curs_choice); cursor = create_cursor(conn, screen, win, curs_choice);
grab_pointer_and_keyboard(conn, screen, cursor); grab_pointer_and_keyboard(conn, screen, cursor);
/* Load the keymap again to sync the current modifier state. Since we first
* loaded the keymap, there might have been changes, but starting from now,
* we should get all key presses/releases due to having grabbed the
* keyboard. */
(void)load_keymap();
if (dpms) if (dpms)
dpms_turn_off_screen(conn); dpms_turn_off_screen(conn);

Loading…
Cancel
Save