From 2a4cd4f6bd9f6b5a43ea6a825e964fb1f4dccd80 Mon Sep 17 00:00:00 2001 From: Dana Jansens Date: Wed, 11 Jul 2007 20:01:47 +0000 Subject: renaming movetofromedge->movetoedge and moveto->moveresizeto --- openbox/actions/movetoedge.c | 77 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 openbox/actions/movetoedge.c (limited to 'openbox/actions/movetoedge.c') diff --git a/openbox/actions/movetoedge.c b/openbox/actions/movetoedge.c new file mode 100644 index 00000000..8a4044be --- /dev/null +++ b/openbox/actions/movetoedge.c @@ -0,0 +1,77 @@ +#include "openbox/actions.h" +#include "openbox/misc.h" +#include "openbox/client.h" +#include "openbox/frame.h" +#include "openbox/geom.h" +#include + +typedef struct { + ObDirection dir; +} 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_movetofromedge_startup() +{ + actions_register("MoveToEdge", + 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->dir = OB_DIRECTION_NORTH; + + if ((n = parse_find_node("direction", node))) { + gchar *s = parse_string(doc, n); + if (!g_ascii_strcasecmp(s, "north") || + !g_ascii_strcasecmp(s, "up")) + o->dir = OB_DIRECTION_NORTH; + else if (!g_ascii_strcasecmp(s, "south") || + !g_ascii_strcasecmp(s, "down")) + o->dir = OB_DIRECTION_SOUTH; + else if (!g_ascii_strcasecmp(s, "west") || + !g_ascii_strcasecmp(s, "left")) + o->dir = OB_DIRECTION_WEST; + else if (!g_ascii_strcasecmp(s, "east") || + !g_ascii_strcasecmp(s, "right")) + o->dir = OB_DIRECTION_EAST; + 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) { + gint x, y; + + client_find_move_directional(data->client, o->dir, &x, &y); + if (x != data->client->area.x || y != data->client->area.y) { + actions_client_move(data, FALSE); + client_move(data->client, x, y); + actions_client_move(data, TRUE); + } + } + + return FALSE; +} -- cgit v1.2.3