summaryrefslogtreecommitdiff
path: root/openbox/keyboard.c
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-05-14 23:31:41 +0000
committerDana Jansens <danakj@orodu.net>2007-05-14 23:31:41 +0000
commitb7827484ef77dc0a62a99da3bc067f6e1950b546 (patch)
tree8a1ca0436aa83e2616283b21086ea8e3a8eea5a3 /openbox/keyboard.c
parent8f2291a7b6feaa64c8c683a62dfef6be95be2eb0 (diff)
ungrab the keyboard for passive grabs. kill interactive actions for exec actions. don't ungrab the keyboard during interactive actions though.
Diffstat (limited to 'openbox/keyboard.c')
-rw-r--r--openbox/keyboard.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/openbox/keyboard.c b/openbox/keyboard.c
index b834046b..ab9d05b0 100644
--- a/openbox/keyboard.c
+++ b/openbox/keyboard.c
@@ -311,6 +311,14 @@ void keyboard_event(ObClient *client, const XEvent *e)
else {
keyboard_reset_chains(0);
+ /* If we don't have the keyboard grabbed, then ungrab it with
+ XUngrabKeyboard, so that there is not a passive grab left
+ on from the KeyPress. If the grab is left on, and focus
+ moves during that time, it will be NotifyWhileGrabbed, and
+ applications like to ignore those! */
+ if (!keyboard_interactively_grabbed())
+ XUngrabKeyboard(ob_display, e->xkey.time);
+
action_run_key(p->actions, client, e->xkey.state,
e->xkey.x_root, e->xkey.y_root,
e->xkey.time);