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 \
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 \
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 \
(*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;
action_send_to_desktop_dir,
setup_action_send_to_desktop_down
},
- {
- "desktop",
- action_desktop,
- setup_action_desktop
- },
{
"desktopnext",
action_desktop_dir,
}
}
-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);
- }
-}
-
void action_desktop_dir(union ActionData *data)
{
guint d;
action_directionaltargetwindow_startup();
action_resize_startup();
action_decorations_startup();
+ action_desktop_startup();
}
void action_directionaltargetwindow_startup();
void action_resize_startup();
void action_decorations_startup();
+void action_desktop_startup();
#endif
--- /dev/null
+#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;
+}