X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fkeyboard.c;h=11b3a98509a058fa6964384342f123f117b13fbc;hb=423d70b41812f01c13b46c7f5a28dc727b337073;hp=54de380c4a38a8fc6d05a381df6ec8370d0230b9;hpb=bdc10887cbb7a51c1231978806963e622619e2f9;p=chaz%2Fopenbox diff --git a/openbox/keyboard.c b/openbox/keyboard.c index 54de380c..11b3a985 100644 --- a/openbox/keyboard.c +++ b/openbox/keyboard.c @@ -39,7 +39,7 @@ KeyBindingTree *keyboard_firstnode; typedef struct { guint state; ObClient *client; - ObAction *action; + GSList *actions; ObFrameContext context; } ObInteractiveState; @@ -162,9 +162,6 @@ void keyboard_interactive_grab(guint state, ObClient *client, g_assert(action->data.any.interactive); - if (moveresize_in_progress) - moveresize_end(FALSE); - if (!interactive_states) { if (!grab_keyboard(TRUE)) return; @@ -178,7 +175,7 @@ void keyboard_interactive_grab(guint state, ObClient *client, s->state = state; s->client = client; - s->action = action; + s->actions = g_slist_append(NULL, action); interactive_states = g_slist_append(interactive_states, s); } @@ -186,8 +183,9 @@ void keyboard_interactive_grab(guint state, ObClient *client, void keyboard_interactive_end(ObInteractiveState *s, guint state, gboolean cancel) { - action_run_interactive(s->action, s->client, state, cancel, TRUE); + action_run_interactive(s->actions, s->client, state, cancel, TRUE); + g_slist_free(s->actions); g_free(s); interactive_states = g_slist_remove(interactive_states, s); @@ -199,18 +197,17 @@ void keyboard_interactive_end(ObInteractiveState *s, } } -void keyboard_interactive_end_client(gpointer data) +void keyboard_interactive_end_client(ObClient *client, gpointer data) { GSList *it, *next; - ObClient *c = data; for (it = interactive_states; it; it = next) { ObInteractiveState *s = it->data; next = g_slist_next(it); - if (s->client == c) - keyboard_interactive_end(s, 0, FALSE); + if (s->client == client) + s->client = NULL; } } @@ -276,13 +273,11 @@ void keyboard_event(ObClient *client, const XEvent *e) curpos = p; grab_keys(TRUE); } else { - GSList *it; - - for (it = p->actions; it; it = it->next) - action_run_key(it->data, client, e->xkey.state, - e->xkey.x_root, e->xkey.y_root); keyboard_reset_chains(); + + action_run_key(p->actions, client, e->xkey.state, + e->xkey.x_root, e->xkey.y_root); } break; } @@ -295,7 +290,7 @@ void keyboard_startup(gboolean reconfig) grab_keys(TRUE); if (!reconfig) - client_add_destructor(keyboard_interactive_end_client); + client_add_destructor(keyboard_interactive_end_client, NULL); } void keyboard_shutdown(gboolean reconfig)