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

index 88cd5e1..de04563 100644 (file)
@@ -161,6 +161,7 @@ openbox_openbox_SOURCES = \
        openbox/actions/cyclewindows.c \
        openbox/actions/debug.c \
        openbox/actions/directionalcyclewindows.c \
+       openbox/actions/directionaltargetwindow.c \
        openbox/actions/execute.c \
        openbox/actions/exit.c \
        openbox/actions/focus.c \
index a952523..b3fd161 100644 (file)
@@ -29,4 +29,5 @@ void action_all_startup()
     action_kill_startup();
     action_omnipresent_startup();
     action_directionalcyclewindows_startup();
+    action_directionaltargetwindow_startup();
 }
index 11f9b7c..2eae206 100644 (file)
@@ -30,5 +30,6 @@ void action_shade_startup();
 void action_kill_startup();
 void action_omnipresent_startup();
 void action_directionalcyclewindows_startup();
+void action_directionaltargetwindow_startup();
 
 #endif
diff --git a/openbox/actions/directionaltargetwindow.c b/openbox/actions/directionaltargetwindow.c
new file mode 100644 (file)
index 0000000..93d33fb
--- /dev/null
@@ -0,0 +1,105 @@
+#include "openbox/actions.h"
+#include "openbox/event.h"
+#include "openbox/focus_cycle.h"
+#include "openbox/openbox.h"
+#include "openbox/misc.h"
+#include "gettext.h"
+
+typedef struct {
+    gboolean dialog;
+    gboolean dock_windows;
+    gboolean desktop_windows;
+    ObDirection direction;
+    GSList *actions;
+} 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_directionaltargetwindow_startup()
+{
+    actions_register("DirectionalTargetWindow",
+                     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->dialog = TRUE;
+
+    if ((n = parse_find_node("dialog", node)))
+        o->dialog = parse_bool(doc, n);
+    if ((n = parse_find_node("panels", node)))
+        o->dock_windows = parse_bool(doc, n);
+    if ((n = parse_find_node("desktop", node)))
+        o->desktop_windows = parse_bool(doc, n);
+    if ((n = parse_find_node("direction", node))) {
+        gchar *s = parse_string(doc, n);
+        if (!g_ascii_strcasecmp(s, "north"))
+            o->direction = OB_DIRECTION_NORTH;
+        else if (!g_ascii_strcasecmp(s, "northwest"))
+            o->direction = OB_DIRECTION_NORTHWEST;
+        else if (!g_ascii_strcasecmp(s, "northeast"))
+            o->direction = OB_DIRECTION_NORTHEAST;
+        else if (!g_ascii_strcasecmp(s, "west"))
+            o->direction = OB_DIRECTION_WEST;
+        else if (!g_ascii_strcasecmp(s, "east"))
+            o->direction = OB_DIRECTION_EAST;
+        else if (!g_ascii_strcasecmp(s, "south"))
+            o->direction = OB_DIRECTION_NORTH;
+        else if (!g_ascii_strcasecmp(s, "southwest"))
+            o->direction = OB_DIRECTION_NORTHWEST;
+        else if (!g_ascii_strcasecmp(s, "southeast"))
+            o->direction = OB_DIRECTION_NORTHEAST;
+        g_free(s);
+    }
+
+    if ((n = parse_find_node("actions", node))) {
+        xmlNodePtr m;
+
+        m = parse_find_node("action", n->xmlChildrenNode);
+        while (m) {
+            ObActionsAct *action = actions_parse(i, doc, m);
+            if (action) o->actions = g_slist_prepend(o->actions, action);
+            m = parse_find_node("action", m->next);
+        }
+    }
+    return o;
+}
+
+static void free_func(gpointer options)
+{
+    Options *o = options;
+
+    g_free(o);
+}
+
+static gboolean run_func(ObActionsData *data, gpointer options)
+{
+    Options *o = options;
+    struct _ObClient *ft;
+
+    /* if using focus_delay, stop the timer now so that focus doesn't go moving
+       on us */
+    event_halt_focus_delay();
+    
+    ft = focus_directional_cycle(o->direction,
+                                 o->dock_windows,
+                                 o->desktop_windows,
+                                 FALSE,
+                                 o->dialog,
+                                 TRUE, FALSE);
+
+    if (ft)
+        actions_run_acts(o->actions, data->uact, data->state,
+                         data->x, data->y, data->button, data->context, ft);
+
+    return FALSE;
+}