X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Fscreen.hh;h=91cf65c3b949784d2f4d40a5e1b2f65ce703cb63;hb=a84666e955ecd0186fbff29aa87a8da9be598435;hp=14e81111a427e6fe6fe3e3fe8597a13279da7b83;hpb=745e840547b5443ecfb9b6f0a4f14b0d035d59c2;p=chaz%2Fopenbox diff --git a/src/screen.hh b/src/screen.hh index 14e81111..91cf65c3 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,10 +88,18 @@ private: //! An offscreen window which gets focus when nothing else has it Window _focuswindow; - + + //! An offscreen window which shows that a NETWM compliant window manager is + //! running + Window _supportwindow; + + //! A list of all managed clients on the screen, in their stacking order + ClientList _stacking; //! Calculate the OBScreen::_area member void calcArea(); + //! Set the list of supported NETWM atoms on the root window + void setSupportedAtoms(); //! Set the client list on the root window /*! Sets the _NET_CLIENT_LIST root window property.
@@ -96,7 +116,7 @@ private: Set the _NET_WORKAREA root window property. */ void setWorkArea(); - + public: #ifndef SWIG //! Constructs a new OBScreen object @@ -105,6 +125,8 @@ public: virtual ~OBScreen(); #endif + inline int number() const { return _number; } + //! Returns if the screen was successfully managed /*! If this is false, then the screen should be deleted and should NOT be @@ -138,6 +160,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); }; }