summarylogtreecommitdiffstats
path: root/uniconify.patch
blob: 831bba1ebe2cbcaf6aa4917b9a44fa34d5b022f5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
diff --git a/Makefile.am b/Makefile.am
index 2d4a0ff..67fb868 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -211,6 +211,7 @@ openbox_openbox_SOURCES = \
 	openbox/actions/fullscreen.c \
 	openbox/actions/growtoedge.c \
 	openbox/actions/iconify.c \
+	openbox/actions/uniconify.c \
 	openbox/actions/if.c \
 	openbox/actions/kill.c \
 	openbox/actions/layer.c \
diff --git a/openbox/actions/all.c b/openbox/actions/all.c
index 07fa51f..8755f64 100644
--- a/openbox/actions/all.c
+++ b/openbox/actions/all.c
@@ -20,6 +20,7 @@ void action_all_startup(void)
     action_raiselower_startup();
     action_unfocus_startup();
     action_iconify_startup();
+    action_uniconify_startup();
     action_fullscreen_startup();
     action_maximize_startup();
     action_moveresizeto_startup();
diff --git a/openbox/actions/all.h b/openbox/actions/all.h
index fc6917e..356f752 100644
--- a/openbox/actions/all.h
+++ b/openbox/actions/all.h
@@ -21,6 +21,7 @@ void action_lower_startup(void);
 void action_raiselower_startup(void);
 void action_unfocus_startup(void);
 void action_iconify_startup(void);
+void action_uniconify_startup(void);
 void action_fullscreen_startup(void);
 void action_maximize_startup(void);
 void action_moveresizeto_startup(void);
diff --git a/openbox/actions/uniconify.c b/openbox/actions/uniconify.c
new file mode 100644
index 0000000..e68981d
--- /dev/null
+++ b/openbox/actions/uniconify.c
@@ -0,0 +1,23 @@
+#include "openbox/actions.h"
+#include "openbox/client.h"
+
+static gboolean run_func(ObActionsData *data, gpointer options);
+
+void action_uniconify_startup(void)
+{
+    actions_register("UnIconify",
+                     NULL, NULL,
+                     run_func);
+}
+
+/* Always return FALSE because its not interactive */
+static gboolean run_func(ObActionsData *data, gpointer options)
+{
+    if (data->client) {
+        actions_client_move(data, TRUE);
+        client_iconify(data->client, FALSE, TRUE, FALSE);
+        actions_client_move(data, FALSE);
+    }
+
+    return FALSE;
+}