summaryrefslogtreecommitdiff
path: root/openbox/stacking.h
diff options
context:
space:
mode:
Diffstat (limited to 'openbox/stacking.h')
-rw-r--r--openbox/stacking.h39
1 files changed, 39 insertions, 0 deletions
diff --git a/openbox/stacking.h b/openbox/stacking.h
new file mode 100644
index 00000000..6286181c
--- /dev/null
+++ b/openbox/stacking.h
@@ -0,0 +1,39 @@
+#ifndef __stacking_h
+#define __stacking_h
+
+#include <glib.h>
+
+struct Client;
+
+/*! The possible stacking layers a client window can be a part of */
+typedef enum {
+ Layer_Icon, /*!< 0 - iconified windows, in any order at all */
+ Layer_Desktop, /*!< 1 - desktop windows */
+ Layer_Below, /*!< 2 - normal windows w/ below */
+ Layer_Normal, /*!< 3 - normal windows */
+ Layer_Above, /*!< 4 - normal windows w/ above */
+ Layer_Top, /*!< 5 - always-on-top-windows (docks?) */
+ Layer_Fullscreen, /*!< 6 - fullscreeen windows */
+ Layer_Internal /*!< 7 - openbox windows/menus */
+} StackLayer;
+
+/* list of Client*s in stacking order from highest to lowest */
+extern GList *stacking_list;
+
+/*! Sets the client stacking list on the root window from the
+ stacking_clientlist */
+void stacking_set_list();
+
+/*! Raises a client window above all others in its stacking layer
+ raiseWindow has a couple of constraints that lowerWindow does not.<br>
+ 1) raiseWindow can be called after changing a Client's stack layer, and
+ the list will be reorganized properly.<br>
+ 2) raiseWindow guarantees that XRestackWindows() will <i>always</i> be
+ called for the specified client.
+*/
+void stacking_raise(struct Client *client);
+
+/*! Lowers a client window below all others in its stacking layer */
+void stacking_lower(struct Client *client);
+
+#endif