summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile.am1
-rw-r--r--openbox/action.c15
-rw-r--r--openbox/actions/all.c1
-rw-r--r--openbox/actions/all.h1
-rw-r--r--openbox/actions/decorations.c62
5 files changed, 65 insertions, 15 deletions
diff --git a/Makefile.am b/Makefile.am
index 4d2b78a8..b067543c 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -160,6 +160,7 @@ openbox_openbox_SOURCES = \
openbox/actions/close.c \
openbox/actions/cyclewindows.c \
openbox/actions/debug.c \
+ openbox/actions/decorations.c \
openbox/actions/directionalcyclewindows.c \
openbox/actions/directionaltargetwindow.c \
openbox/actions/execute.c \
diff --git a/openbox/action.c b/openbox/action.c
index 61c29721..2dca0dd5 100644
--- a/openbox/action.c
+++ b/openbox/action.c
@@ -433,11 +433,6 @@ ActionString actionstrings[] =
setup_action_desktop_down
},
{
- "toggledecorations",
- action_toggle_decorations,
- setup_client_action
- },
- {
"toggledockautohide",
action_toggle_dockautohide,
NULL
@@ -890,16 +885,6 @@ void action_desktop_last(union ActionData *data)
screen_set_desktop(screen_last_desktop, TRUE);
}
-void action_toggle_decorations(union ActionData *data)
-{
- ObClient *c = data->client.any.c;
-
- client_action_start(data);
- client_set_undecorated(c, !c->undecorated);
- client_action_end(data, FALSE);
-}
-
-
void action_directional_focus(union ActionData *data)
{
/* if using focus_delay, stop the timer now so that focus doesn't go moving
diff --git a/openbox/actions/all.c b/openbox/actions/all.c
index c41c5f85..7297d235 100644
--- a/openbox/actions/all.c
+++ b/openbox/actions/all.c
@@ -31,4 +31,5 @@ void action_all_startup()
action_directionalcyclewindows_startup();
action_directionaltargetwindow_startup();
action_resize_startup();
+ action_decorations_startup();
}
diff --git a/openbox/actions/all.h b/openbox/actions/all.h
index cae50318..477b5fe9 100644
--- a/openbox/actions/all.h
+++ b/openbox/actions/all.h
@@ -32,5 +32,6 @@ void action_omnipresent_startup();
void action_directionalcyclewindows_startup();
void action_directionaltargetwindow_startup();
void action_resize_startup();
+void action_decorations_startup();
#endif
diff --git a/openbox/actions/decorations.c b/openbox/actions/decorations.c
new file mode 100644
index 00000000..8a816ae4
--- /dev/null
+++ b/openbox/actions/decorations.c
@@ -0,0 +1,62 @@
+#include "openbox/actions.h"
+#include "openbox/client.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_decorations_startup()
+{
+ actions_register("Decorations",
+ 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("decorations", 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) {
+ actions_client_move(data, TRUE);
+ if (o->toggle || o->on != !data->client->undecorated)
+ client_set_undecorated(data->client, !data->client->undecorated);
+ actions_client_move(data, FALSE);
+ }
+
+ return FALSE;
+}