add omnipresent action
authorDana Jansens <danakj@orodu.net>
Fri, 22 Jun 2007 15:59:07 +0000 (15:59 +0000)
committerDana Jansens <danakj@orodu.net>
Fri, 22 Jun 2007 15:59:07 +0000 (15:59 +0000)
Makefile.am
openbox/action.c
openbox/actions/all.c
openbox/actions/all.h
openbox/actions/omnipresent.c [new file with mode: 0644]

index 15c2208..612dca0 100644 (file)
@@ -173,6 +173,7 @@ openbox_openbox_SOURCES = \
        openbox/actions/move.c \
        openbox/actions/moverelative.c \
        openbox/actions/moveto.c \
+       openbox/actions/omnipresent.c \
        openbox/actions/raise.c \
        openbox/actions/raiselower.c \
        openbox/actions/reconfigure.c \
index bc1db10..110a9fd 100644 (file)
@@ -465,11 +465,6 @@ ActionString actionstrings[] =
         setup_client_action
     },
     {
-        "toggleomnipresent",
-        action_toggle_omnipresent,
-        setup_client_action
-    },
-    {
         "resizerelativevert",
         action_resize_relative_vert,
         setup_client_action
@@ -920,13 +915,6 @@ void action_shadelower(union ActionData *data)
         action_shade(data);
 }
 
-void action_toggle_omnipresent(union ActionData *data)
-{ 
-    client_set_desktop(data->client.any.c,
-                       data->client.any.c->desktop == DESKTOP_ALL ?
-                       screen_desktop : DESKTOP_ALL, FALSE, TRUE);
-}
-
 void action_resize_relative_horz(union ActionData *data)
 {
     ObClient *c = data->relative.any.c;
index 9b11b49..f303c09 100644 (file)
@@ -27,4 +27,5 @@ void action_all_startup()
     action_moverelative_startup();
     action_shade_startup();
     action_kill_startup();
+    action_omnipresent_startup();
 }
index 265ec42..17bba0a 100644 (file)
@@ -28,5 +28,6 @@ void action_moveto_startup();
 void action_moverelative_startup();
 void action_shade_startup();
 void action_kill_startup();
+void action_omnipresent_startup();
 
 #endif
diff --git a/openbox/actions/omnipresent.c b/openbox/actions/omnipresent.c
new file mode 100644 (file)
index 0000000..02bd991
--- /dev/null
@@ -0,0 +1,62 @@
+#include "openbox/actions.h"
+#include "openbox/client.h"
+#include "openbox/screen.h"
+
+typedef struct {
+    gboolean toggle;
+    gboolean on;
+} 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_omnipresent_startup()
+{
+    actions_register("omnipresent",
+                     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);
+    o->toggle = TRUE;
+
+    if ((n = parse_find_node("omnipresent", node))) {
+        gchar *s = parse_string(doc, n);
+        if (g_ascii_strcasecmp(s, "toggle")) {
+            o->toggle = FALSE;
+            o->on = parse_bool(doc, n);
+        }
+        g_free(s);
+    }
+
+    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 (data->client)
+        if (o->toggle || (o->on != (data->client->desktop == DESKTOP_ALL)))
+            client_set_desktop(data->client,
+                               data->client->desktop == DESKTOP_ALL ?
+                               screen_desktop : DESKTOP_ALL, FALSE, TRUE);
+
+    return FALSE;
+}