X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2FWorkspace.h;h=9b7aba101e6ab69975dc68179170cbab5e1bea96;hb=57fb41c8060eaa2f29b25b08e3813b3dc140f165;hp=1091f8864e0d36b5ddf25023bc67c8842696d2f9;hpb=df9d0c891ad0df9e91397f07fa439fea1e405b2b;p=chaz%2Fopenbox diff --git a/src/Workspace.h b/src/Workspace.h index 1091f886..9b7aba10 100644 --- a/src/Workspace.h +++ b/src/Workspace.h @@ -25,13 +25,18 @@ #include -#include "LinkedList.h" -#include "Geometry.h" +#include +#include class BScreen; class Clientmenu; class Workspace; class OpenboxWindow; +class Size; +class Rect; + +typedef std::vector winVect; +typedef std::list winList; class Workspace { private: @@ -39,43 +44,39 @@ private: OpenboxWindow *lastfocus; Clientmenu *clientmenu; - LinkedList *stackingList, *windowList; + winVect _windows; + winList _zorder; char *name; int id, cascade_x, cascade_y; + OpenboxWindow *_focused; protected: - void placeWindow(OpenboxWindow *); + void placeWindow(OpenboxWindow &); Point *bestFitPlacement(const Size &win_size, const Rect &space); + Point *underMousePlacement(const Size &win_size, const Rect &space); Point *rowSmartPlacement(const Size &win_size, const Rect &space); - Point *cascade(const OpenboxWindow* window); + Point *colSmartPlacement(const Size &win_size, const Rect &space); + Point *const cascadePlacement(const OpenboxWindow &window, const Rect &space); public: Workspace(BScreen &, int = 0); ~Workspace(void); inline BScreen &getScreen(void) { return screen; } - inline OpenboxWindow *getLastFocusedWindow(void) { return lastfocus; } - inline Clientmenu *getMenu(void) { return clientmenu; } - inline const char *getName(void) const { return name; } - inline const int &getWorkspaceID(void) const { return id; } - inline void setLastFocusedWindow(OpenboxWindow *w) { lastfocus = w; } - + inline OpenboxWindow *focusedWindow() { return _focused; } + void focusWindow(OpenboxWindow *win); OpenboxWindow *getWindow(int); - Bool isCurrent(void); - Bool isLastWindow(OpenboxWindow *); - const int addWindow(OpenboxWindow *, Bool = False); const int removeWindow(OpenboxWindow *); const int getCount(void); - void showAll(void); void hideAll(void); void removeAll(void); @@ -84,7 +85,7 @@ public: void reconfigure(); void update(); void setCurrent(void); - void setName(char *); + void setName(const char *); void shutdown(void); };