X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fscreen.hh;h=5af79366acf764a3d60dc703bf60b1f43d97fcc5;hb=660ad41ca0b1c48525bba071a27def141ad1cbfe;hp=14e81111a427e6fe6fe3e3fe8597a13279da7b83;hpb=745e840547b5443ecfb9b6f0a4f14b0d035d59c2;p=chaz%2Fopenbox diff --git a/src/screen.hh b/src/screen.hh index 14e81111..5af79366 100644 --- a/src/screen.hh +++ b/src/screen.hh @@ -43,7 +43,19 @@ public: ButtonPressMask | ButtonReleaseMask; - //! All managed clients on the screen + enum StackLayer { + 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 + NUM_LAYERS + }; + + //! All managed clients on the screen (in order of being mapped) ClientList clients; private: @@ -76,7 +88,9 @@ private: //! An offscreen window which gets focus when nothing else has it Window _focuswindow; - + + //! A list of all managed clients on the screen, in their stacking order + ClientList _stacking; //! Calculate the OBScreen::_area member void calcArea(); @@ -96,7 +110,7 @@ private: Set the _NET_WORKAREA root window property. */ void setWorkArea(); - + public: #ifndef SWIG //! Constructs a new OBScreen object @@ -138,6 +152,10 @@ public: it, etc. */ void unmanageWindow(OBClient *client); + + //! Raises/Lowers a client window above/below all others in its stacking + //! layer + void restack(bool raise, OBClient *client); }; }