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:
parent
1a23a1bb8b
commit
fce33883f4
1 changed files with 17 additions and 8 deletions
|
@ -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 ||
|
||||||
|
|
Loading…
Reference in a new issue