From d363f720a6b0d1c361bc2022d0e5fcd5a75fd04d Mon Sep 17 00:00:00 2001 From: Dana Jansens Date: Wed, 6 Nov 2002 08:06:54 +0000 Subject: fix compiling with the new strut (new namespace) and fix general errors that broke compiling. make xeventhandler find the OBClient for most events.. --- src/openbox.hh | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'src/openbox.hh') diff --git a/src/openbox.hh b/src/openbox.hh index baf9edeb..bb05fae8 100644 --- a/src/openbox.hh +++ b/src/openbox.hh @@ -12,11 +12,13 @@ extern "C" { #include #include +#include #include "otk/screeninfo.hh" #include "otk/timerqueuemanager.hh" #include "otk/property.hh" #include "xeventhandler.hh" +#include "client.hh" namespace ob { @@ -46,6 +48,9 @@ public: State_Normal, //!< The window manager is running in its normal state State_Exiting //!< The window manager is exiting (being destroyed) }; + + //! A map for looking up a specific client class from the window id + typedef std::map ClientMap; private: // stuff that can be passed on the command line @@ -64,6 +69,9 @@ private: //! The value of argv[0], i.e. how this application was executed char *_argv0; + //! A list of all managed clients + ClientMap _clients; + //! Manages all timers for the application /*! Use of the otk::OBTimerQueueManager::fire funtion in this object ensures @@ -128,6 +136,15 @@ public: */ void eventLoop(); + //! Adds an OBClient to the client list for lookups + void addClient(Window window, OBClient *client); + + //! Removes an OBClient from the client list for lookups + void removeClient(Window window); + + //! Finds an OBClient based on its window id + OBClient *findClient(Window window); + //! Requests that the window manager exit /*! Causes the Openbox::eventLoop function to stop looping, so that the window -- cgit v1.2.3