#include "openbox/actions.h"
#include "openbox/client.h"
-static gboolean run_func(ObActionsData *data, gpointer options);
+/* These match the values for client_maximize */
+typedef enum {
+ BOTH = 0,
+ HORZ = 1,
+ VERT = 2
+} MaxDirection;
-void action_maximize_startup()
+typedef struct {
+ MaxDirection dir;
+} Options;
+
+static gpointer setup_func(xmlNodePtr node);
+static gboolean run_func_on(ObActionsData *data, gpointer options);
+static gboolean run_func_off(ObActionsData *data, gpointer options);
+static gboolean run_func_toggle(ObActionsData *data, gpointer options);
+/* 3.4-compatibility */
+static gpointer setup_both_func(xmlNodePtr node);
+static gpointer setup_horz_func(xmlNodePtr node);
+static gpointer setup_vert_func(xmlNodePtr node);
+
+void action_maximize_startup(void)
+{
+ actions_register("Maximize", setup_func, g_free, run_func_on);
+ actions_register("Unmaximize", setup_func, g_free, run_func_off);
+ actions_register("ToggleMaximize", setup_func, g_free, run_func_toggle);
+ /* 3.4-compatibility */
+ actions_register("MaximizeFull", setup_both_func, g_free,
+ run_func_on);
+ actions_register("UnmaximizeFull", setup_both_func, g_free,
+ run_func_off);
+ actions_register("ToggleMaximizeFull", setup_both_func, g_free,
+ run_func_toggle);
+ actions_register("MaximizeHorz", setup_horz_func, g_free,
+ run_func_on);
+ actions_register("UnmaximizeHorz", setup_horz_func, g_free,
+ run_func_off);
+ actions_register("ToggleMaximizeHorz", setup_horz_func, g_free,
+ run_func_toggle);
+ actions_register("MaximizeVert", setup_vert_func, g_free,
+ run_func_on);
+ actions_register("UnmaximizeVert", setup_vert_func, g_free,
+ run_func_off);
+ actions_register("ToggleMaximizeVert", setup_vert_func, g_free,
+ run_func_toggle);
+}
+
+static gpointer setup_func(xmlNodePtr node)
+{
+ xmlNodePtr n;
+ Options *o;
+
+ o = g_new0(Options, 1);
+ o->dir = BOTH;
+
+ if ((n = obt_xml_find_node(node, "direction"))) {
+ gchar *s = obt_xml_node_string(n);
+ if (!g_ascii_strcasecmp(s, "vertical") ||
+ !g_ascii_strcasecmp(s, "vert"))
+ o->dir = VERT;
+ else if (!g_ascii_strcasecmp(s, "horizontal") ||
+ !g_ascii_strcasecmp(s, "horz"))
+ o->dir = HORZ;
+ g_free(s);
+ }
+
+ return o;
+}
+
+/* Always return FALSE because its not interactive */
+static gboolean run_func_on(ObActionsData *data, gpointer options)
{
- actions_register("Maximize",
- NULL, NULL,
- run_func,
- NULL, NULL);
+ Options *o = options;
+ if (data->client) {
+ actions_client_move(data, TRUE);
+ client_maximize(data->client, TRUE, o->dir);
+ actions_client_move(data, FALSE);
+ }
+ return FALSE;
}
/* Always return FALSE because its not interactive */
-static gboolean run_func(ObActionsData *data, gpointer options)
+static gboolean run_func_off(ObActionsData *data, gpointer options)
{
+ Options *o = options;
if (data->client) {
actions_client_move(data, TRUE);
- client_maximize(data->client,
- !(data->client->max_horz || data->client->max_vert),
- 0);
+ client_maximize(data->client, FALSE, o->dir);
actions_client_move(data, FALSE);
}
+ return FALSE;
+}
+/* Always return FALSE because its not interactive */
+static gboolean run_func_toggle(ObActionsData *data, gpointer options)
+{
+ Options *o = options;
+ if (data->client) {
+ gboolean toggle;
+ actions_client_move(data, TRUE);
+ toggle = ((o->dir == HORZ && !data->client->max_horz) ||
+ (o->dir == VERT && !data->client->max_vert) ||
+ (o->dir == BOTH &&
+ !(data->client->max_horz && data->client->max_vert)));
+ client_maximize(data->client, toggle, o->dir);
+ actions_client_move(data, FALSE);
+ }
return FALSE;
}
+
+/* 3.4-compatibility */
+static gpointer setup_both_func(xmlNodePtr node)
+{
+ Options *o = g_new0(Options, 1);
+ o->dir = BOTH;
+ return o;
+}
+
+static gpointer setup_horz_func(xmlNodePtr node)
+{
+ Options *o = g_new0(Options, 1);
+ o->dir = HORZ;
+ return o;
+}
+
+static gpointer setup_vert_func(xmlNodePtr node)
+{
+ Options *o = g_new0(Options, 1);
+ o->dir = VERT;
+ return o;
+}
+