fix for running actions that end up wanting to grab the keyboard. make a nicer comment about what is going on.

This commit is contained in:
Dana Jansens 2007-05-12 19:26:48 +00:00
parent 1a23a1bb8b
commit fce33883f4

View file

@ -1101,12 +1101,20 @@ void action_run_list(GSList *acts, ObClient *c, ObFrameContext context,
} }
} }
if (!inter) { if (!inter && button == 0) {
/* sometimes when we execute another app as an action, /* Ungrab the keyboard before running the action, if it was
it won't work right unless we XUngrabKeyboard first, not from a mouse event.
even though we grabbed the key/button Asychronously.
e.g. "gnome-panel-control --main-menu" */ We have to do this because a key press causes a passive
grab_keyboard(FALSE); grab on the keyboard, and so if the action we are running
wants to grab the keyboard, it will fail if the button is still
held down (which is likely).
Use the X function not out own, because we're not considering
a grab to be in place at all so our function won't try ungrab
anything.
*/
XUngrabKeyboard(ob_display, time);
} }
for (it = acts; it; it = g_slist_next(it)) { for (it = acts; it; it = g_slist_next(it)) {
@ -1138,8 +1146,9 @@ void action_run_list(GSList *acts, ObClient *c, ObFrameContext context,
{ {
/* interactive actions are not queued */ /* interactive actions are not queued */
a->func(&a->data); a->func(&a->data);
} else if ((context == OB_FRAME_CONTEXT_CLIENT || } else if (c &&
(c && c->type == OB_CLIENT_TYPE_DESKTOP && (context == OB_FRAME_CONTEXT_CLIENT ||
(c->type == OB_CLIENT_TYPE_DESKTOP &&
context == OB_FRAME_CONTEXT_DESKTOP)) && context == OB_FRAME_CONTEXT_DESKTOP)) &&
(a->func == action_focus || (a->func == action_focus ||
a->func == action_activate || a->func == action_activate ||