all repos — openbox @ 16f2b255cb3e504f7695bc94ec691f949bf6722d

openbox fork - make it a bit more like ryudo

add the desktop action
Dana Jansens danakj@orodu.net
commit

16f2b255cb3e504f7695bc94ec691f949bf6722d

parent

5d350da82e9fc46aa59e59c255604429add2d1ed

5 files changed, 54 insertions(+), 26 deletions(-)

jump to
M Makefile.amMakefile.am

@@ -161,6 +161,7 @@ openbox/actions/close.c \

openbox/actions/cyclewindows.c \ openbox/actions/debug.c \ openbox/actions/decorations.c \ + openbox/actions/desktop.c \ openbox/actions/directionalcyclewindows.c \ openbox/actions/directionaltargetwindow.c \ openbox/actions/execute.c \

@@ -173,6 +174,7 @@ openbox/actions/lower.c \

openbox/actions/maximize.c \ openbox/actions/maximizehorizontal.c \ openbox/actions/maximizevertical.c \ + openbox/actions/menu.c \ openbox/actions/move.c \ openbox/actions/moverelative.c \ openbox/actions/moveto.c \

@@ -184,7 +186,6 @@ openbox/actions/resize.c \

openbox/actions/restart.c \ openbox/actions/shade.c \ openbox/actions/showdesktop.c \ - openbox/actions/showmenu.c \ openbox/actions/unfocus.c \ openbox/actions.c \ openbox/actions.h \
M openbox/action.copenbox/action.c

@@ -162,13 +162,6 @@ (*a)->data.sendtodir.wrap = TRUE;

(*a)->data.sendtodir.follow = TRUE; } -void setup_action_desktop(ObAction **a, ObUserAction uact) -{ -/* - (*a)->data.desktop.inter.any.interactive = FALSE; -*/ -} - void setup_action_desktop_prev(ObAction **a, ObUserAction uact) { (*a)->data.desktopdir.inter.any.interactive = TRUE;

@@ -396,11 +389,6 @@ {

"sendtodesktopdown", action_send_to_desktop_dir, setup_action_send_to_desktop_down - }, - { - "desktop", - action_desktop, - setup_action_desktop }, { "desktopnext",

@@ -818,19 +806,6 @@ data->sendto.desk == DESKTOP_ALL) {

client_set_desktop(c, data->sendto.desk, data->sendto.follow, FALSE); if (data->sendto.follow && data->sendto.desk != screen_desktop) screen_set_desktop(data->sendto.desk, TRUE); - } -} - -void action_desktop(union ActionData *data) -{ - /* XXX add the interactive/dialog option back again once the dialog - has been made to not use grabs */ - if (data->desktop.desk < screen_num_desktops || - data->desktop.desk == DESKTOP_ALL) - { - screen_set_desktop(data->desktop.desk, TRUE); - if (data->inter.any.interactive) - screen_desktop_popup(data->desktop.desk, TRUE); } }
M openbox/actions/all.copenbox/actions/all.c

@@ -32,4 +32,5 @@ action_directionalcyclewindows_startup();

action_directionaltargetwindow_startup(); action_resize_startup(); action_decorations_startup(); + action_desktop_startup(); }
M openbox/actions/all.hopenbox/actions/all.h

@@ -33,5 +33,6 @@ void action_directionalcyclewindows_startup();

void action_directionaltargetwindow_startup(); void action_resize_startup(); void action_decorations_startup(); +void action_desktop_startup(); #endif
A openbox/actions/desktop.c

@@ -0,0 +1,50 @@

+#include "openbox/actions.h" +#include "openbox/screen.h" +#include <glib.h> + +typedef struct { + guint desktop; +} Options; + +static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node); +static void free_func(gpointer options); +static gboolean run_func(ObActionsData *data, gpointer options); + +void action_desktop_startup() +{ + actions_register("desktop", + setup_func, + free_func, + run_func, + NULL, NULL); +} + +static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node) +{ + xmlNodePtr n; + Options *o; + + o = g_new0(Options, 1); + + if ((n = parse_find_node("desktop", node))) + o->desktop = parse_int(doc, n) - 1; + return o; +} + +static void free_func(gpointer options) +{ + Options *o = options; + + g_free(o); +} + +/* Always return FALSE because its not interactive */ +static gboolean run_func(ObActionsData *data, gpointer options) +{ + Options *o = options; + + if (o->desktop < screen_num_desktops) + screen_set_desktop(o->desktop, TRUE); + + return FALSE; +}