summaryrefslogtreecommitdiff
path: root/openbox/keyboard.c
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2008-02-18 15:55:59 -0500
committerDana Jansens <danakj@orodu.net>2008-02-18 20:42:35 -0500
commit5bfa48dcffec3b00d119d851cb2427a43f80aa7b (patch)
tree93c1c776e36d1b376241dbe1c5ccf1d4450b86d1 /openbox/keyboard.c
parent58788c781713092c6aa3a4544f8a06cd499ec4fd (diff)
Grab key bindings with GrabModeSync, so that if they lead to a keyboard grab, then no keyboard events will be lost between the initial keybinding and the keyboard grab.
Diffstat (limited to 'openbox/keyboard.c')
-rw-r--r--openbox/keyboard.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/openbox/keyboard.c b/openbox/keyboard.c
index c23d83e6..c318a4cf 100644
--- a/openbox/keyboard.c
+++ b/openbox/keyboard.c
@@ -53,13 +53,13 @@ static void grab_keys(gboolean grab)
while (p) {
if (p->key)
grab_key(p->key, p->state, RootWindow(ob_display, ob_screen),
- GrabModeAsync);
+ GrabModeSync);
p = p->next_sibling;
}
if (curpos)
grab_key(config_keyboard_reset_keycode,
config_keyboard_reset_state,
- RootWindow(ob_display, ob_screen), GrabModeAsync);
+ RootWindow(ob_display, ob_screen), GrabModeSync);
}
}
@@ -263,6 +263,8 @@ void keyboard_event(ObClient *client, const XEvent *e)
}
p = p->next_sibling;
}
+
+ XAllowEvents(ob_display, AsyncKeyboard, event_curtime);
}
static void node_rebind(KeyBindingTree *node)