X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fclient_list_menu.c;h=9b904f4dc6fe6c184d926a5c772e160206812548;hb=8fe0cb8989c1fe12b30b9030b446345f25340d35;hp=65f8ad5ed3de90b35781f459aef5d783712edc3b;hpb=ea2f33e9ee65856faef6617d013270e9898d9911;p=chaz%2Fopenbox diff --git a/openbox/client_list_menu.c b/openbox/client_list_menu.c index 65f8ad5e..9b904f4d 100644 --- a/openbox/client_list_menu.c +++ b/openbox/client_list_menu.c @@ -17,8 +17,6 @@ typedef struct { guint desktop; } DesktopData; -void plugin_setup_config() { } - static void desk_menu_update(ObMenuFrame *frame, gpointer data) { ObMenu *menu = frame->menu; @@ -42,7 +40,8 @@ static void desk_menu_update(ObMenuFrame *frame, gpointer data) menu_add_separator(menu, -1); } - act = action_from_string("activate"); + act = action_from_string("Activate", + OB_USER_ACTION_MENU_SELECTION); act->data.activate.any.c = c; acts = g_slist_prepend(NULL, act); e = menu_add_normal(menu, i, @@ -58,16 +57,16 @@ static void desk_menu_update(ObMenuFrame *frame, gpointer data) } -/* executes it without changing the client in the actions, since we set that +/* executes it using the client in the actions, since we set that when we make the actions! */ -static void desk_menu_execute(ObMenuEntry *self, gpointer data) +static void desk_menu_execute(ObMenuEntry *self, guint state, gpointer data) { GSList *it; for (it = self->data.normal.actions; it; it = g_slist_next(it)) { ObAction *act = it->data; - act->func(&act->data); + action_run(it->data, act->data.any.c, state); } } @@ -76,6 +75,8 @@ static void desk_menu_destroy(ObMenu *menu, gpointer data) DesktopData *d = data; g_free(d); + + desktop_menus = g_slist_remove(desktop_menus, menu); } static void self_update(ObMenuFrame *frame, gpointer data)