summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-07-22 09:32:30 -0400
committerDana Jansens <danakj@orodu.net>2007-07-22 09:32:30 -0400
commit172e93b3505e616160cc5035b4e3e80e3a40a485 (patch)
tree1a282cef580db5e92a9c8c1188f8ea30fafff23b
parent64c59b7456bb99293e0c4c95871bed4361c9bd36 (diff)
add an 'all' option for the monitor in MoveResizeTo
-rw-r--r--openbox/actions/moveresizeto.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/openbox/actions/moveresizeto.c b/openbox/actions/moveresizeto.c
index 48b6e3bf..0e1f8268 100644
--- a/openbox/actions/moveresizeto.c
+++ b/openbox/actions/moveresizeto.c
@@ -4,6 +4,11 @@
#include "openbox/frame.h"
#include <stdlib.h> /* for atoi */
+enum {
+ CURRENT_MONITOR = -1,
+ ALL_MONITORS = -2
+};
+
typedef struct {
gboolean xcenter;
gboolean ycenter;
@@ -58,7 +63,7 @@ static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node)
o->y = G_MININT;
o->w = G_MININT;
o->h = G_MININT;
- o->monitor = -1;
+ o->monitor = CURRENT_MONITOR;
if ((n = parse_find_node("x", node)))
parse_coord(doc, n, &o->x, &o->xopposite, &o->xcenter);
@@ -81,8 +86,12 @@ static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node)
if ((n = parse_find_node("monitor", node))) {
gchar *s = parse_string(doc, n);
- if (g_ascii_strcasecmp(s, "current") != 0)
- o->monitor = parse_int(doc, n) - 1;
+ if (g_ascii_strcasecmp(s, "current") != 0) {
+ if (!g_ascii_strcasecmp(s, "all"))
+ o->monitor = ALL_MONITORS;
+ else
+ o->monitor = parse_int(doc, n) - 1;
+ }
g_free(s);
}
@@ -110,7 +119,8 @@ static gboolean run_func(ObActionsData *data, gpointer options)
c = data->client;
mon = o->monitor;
cmon = client_monitor(c);
- if (mon < 0) mon = cmon;
+ if (mon == CURRENT_MONITOR) mon = cmon;
+ else if (mon == ALL_MONITORS) mon = SCREEN_AREA_ALL_MONITORS;
area = screen_area(c->desktop, mon, NULL);
carea = screen_area(c->desktop, cmon, NULL);