// Screen.hh for Fluxbox Window Manager // Copyright (c) 2001 - 2002 Henrik Kinnunen (fluxgen@linuxmail.org) // // Screen.hh for Blackbox - an X11 Window manager // Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net) // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the "Software"), // to deal in the Software without restriction, including without limitation // the rights to use, copy, modify, merge, publish, distribute, sublicense, // and/or sell copies of the Software, and to permit persons to whom the // Software is furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER // DEALINGS IN THE SOFTWARE. // $Id: Screen.hh,v 1.38 2002/07/23 13:47:05 fluxgen Exp $ #ifndef SCREEN_HH #define SCREEN_HH #include "Theme.hh" #include "BaseDisplay.hh" #include "Configmenu.hh" #include "Icon.hh" #include "Netizen.hh" #include "Rootmenu.hh" #include "Timer.hh" #include "Workspace.hh" #include "Workspacemenu.hh" #include "fluxbox.hh" #ifdef SLIT # include "Slit.hh" #endif // SLIT #include <X11/Xlib.h> #include <X11/Xresource.h> #ifdef TIME_WITH_SYS_TIME # include <sys/time.h> # include <time.h> #else // !TIME_WITH_SYS_TIME # ifdef HAVE_SYS_TIME_H # include <sys/time.h> # else // !HAVE_SYS_TIME_H # include <time.h> # endif // HAVE_SYS_TIME_H #endif // TIME_WITH_SYS_TIME #include <stdio.h> #include <string> #include <list> #include <vector> #include <fstream> class BScreen : public ScreenInfo { public: BScreen(ResourceManager &rm, Fluxbox *b, const std::string &screenname, const std::string &altscreenname, int scrn); ~BScreen(); inline bool isToolbarOnTop(void) const { return *resource.toolbar_on_top; } inline bool doToolbarAutoHide(void) const { return *resource.toolbar_auto_hide; } inline bool isSloppyFocus(void) const { return resource.sloppy_focus; } inline bool isSemiSloppyFocus(void) const { return resource.semi_sloppy_focus; } inline bool isRootColormapInstalled(void) const { return root_colormap_installed; } inline bool isScreenManaged(void) const { return managed; } inline bool isTabRotateVertical(void) const { return *resource.tab_rotate_vertical; } inline bool isSloppyWindowGrouping(void) const { return *resource.sloppy_window_grouping; } inline bool isWorkspaceWarping(void) const { return *resource.workspace_warping; } inline bool isDesktopWheeling(void) const { return *resource.desktop_wheeling; } inline bool doAutoRaise(void) const { return resource.auto_raise; } inline bool doImageDither(void) const { return *resource.image_dither; } inline bool doMaxOverSlit(void) const { return *resource.max_over_slit; } inline bool doOpaqueMove(void) const { return *resource.opaque_move; } inline bool doFullMax(void) const { return *resource.full_max; } inline bool doFocusNew(void) const { return *resource.focus_new; } inline bool doFocusLast(void) const { return *resource.focus_last; } inline bool doShowWindowPos(void) const { return *resource.show_window_pos; } inline const GC &getOpGC() const { return theme->getOpGC(); } inline const FbTk::Color *getBorderColor(void) const { return &theme->getBorderColor(); } inline BImageControl *getImageControl(void) { return image_control; } inline Rootmenu *getRootmenu(void) { return rootmenu; } inline const std::string &getRootCommand(void ) const { return *resource.rootcommand; } #ifdef SLIT inline bool isSlitOnTop(void) const { return resource.slit_on_top; } inline bool doSlitAutoHide(void) const { return resource.slit_auto_hide; } inline Slit *getSlit(void) { return slit; } inline int getSlitPlacement(void) const { return resource.slit_placement; } inline int getSlitDirection(void) const { return resource.slit_direction; } inline void saveSlitPlacement(int p) { resource.slit_placement = p; } inline void saveSlitDirection(int d) { resource.slit_direction = d; } inline void saveSlitOnTop(bool t) { resource.slit_on_top = t; } inline void saveSlitAutoHide(bool t) { resource.slit_auto_hide = t; } #ifdef XINERAMA inline unsigned int getSlitOnHead(void) const { return resource.slit_on_head; } inline void saveSlitOnHead(unsigned int h) { resource.slit_on_head = h; } #endif // XINERAMA #endif // SLIT inline Toolbar *getToolbar(void) { return toolbar; } inline Workspace *getWorkspace(unsigned int w) { return ( w < workspacesList.size() ? workspacesList[w] : 0); } inline Workspace *getCurrentWorkspace(void) { return current_workspace; } inline Workspacemenu *getWorkspacemenu(void) { return workspacemenu; } inline unsigned int getHandleWidth(void) const { return theme->getHandleWidth(); } inline unsigned int getBevelWidth(void) const { return theme->getBevelWidth(); } inline unsigned int getFrameWidth(void) const { return theme->getFrameWidth(); } inline unsigned int getBorderWidth(void) const { return theme->getBorderWidth(); } inline unsigned int getBorderWidth2x(void) const { return theme->getBorderWidth()*2; } inline unsigned int getCurrentWorkspaceID() const { return current_workspace->workspaceID(); } typedef std::vector<FluxboxWindow *> Icons; inline unsigned int getCount(void) const { return workspacesList.size(); } inline unsigned int getIconCount(void) const { return iconList.size(); } inline const Icons &getIconList(void) const { return iconList; } inline Icons &getIconList(void) { return iconList; } inline int getNumberOfWorkspaces(void) const { return *resource.workspaces; } inline Toolbar::Placement getToolbarPlacement(void) const { return *resource.toolbar_placement; } #ifdef XINERAMA inline int getToolbarOnHead(void) { return *resource.toolbar_on_head; } #endif // XINERAMA inline int getToolbarWidthPercent(void) const { return *resource.toolbar_width_percent; } inline int getPlacementPolicy(void) const { return resource.placement_policy; } inline int getEdgeSnapThreshold(void) const { return *resource.edge_snap_threshold; } inline int getRowPlacementDirection(void) const { return resource.row_direction; } inline int getColPlacementDirection(void) const { return resource.col_direction; } inline unsigned int getTabWidth(void) const { return *resource.tab_width; } inline unsigned int getTabHeight(void) const { return *resource.tab_height; } inline Tab::Placement getTabPlacement(void) const { return *resource.tab_placement; } inline Tab::Alignment getTabAlignment(void) const { return *resource.tab_alignment; } inline void setRootColormapInstalled(Bool r) { root_colormap_installed = r; } inline void saveRootCommand(std::string rootcmd) { *resource.rootcommand = rootcmd; } inline void saveSloppyFocus(bool s) { resource.sloppy_focus = s; } inline void saveSemiSloppyFocus(bool s) { resource.semi_sloppy_focus = s; } inline void saveAutoRaise(bool a) { resource.auto_raise = a; } inline void saveWorkspaces(int w) { *resource.workspaces = w; } inline void saveToolbarOnTop(bool r) { *resource.toolbar_on_top = r; } inline void saveToolbarAutoHide(bool r) { *resource.toolbar_auto_hide = r; } inline void saveToolbarWidthPercent(int w) { *resource.toolbar_width_percent = w; } inline void saveToolbarPlacement(Toolbar::Placement p) { *resource.toolbar_placement = p; } #ifdef XINERAMA inline void saveToolbarOnHead(int head) { *resource.toolbar_on_head = head; } #endif // XINERAMA inline void savePlacementPolicy(int p) { resource.placement_policy = p; } inline void saveRowPlacementDirection(int d) { resource.row_direction = d; } inline void saveColPlacementDirection(int d) { resource.col_direction = d; } inline void saveEdgeSnapThreshold(int t) { resource.edge_snap_threshold = t; } inline void saveImageDither(bool d) { resource.image_dither = d; } inline void saveMaxOverSlit(bool m) { resource.max_over_slit = m; } inline void saveOpaqueMove(bool o) { resource.opaque_move = o; } inline void saveFullMax(bool f) { resource.full_max = f; } inline void saveFocusNew(bool f) { resource.focus_new = f; } inline void saveFocusLast(bool f) { resource.focus_last = f; } inline void saveTabWidth(unsigned int w) { resource.tab_width = w; } inline void saveTabHeight(unsigned int h) { resource.tab_height = h; } inline void saveTabPlacement(Tab::Placement p) { *resource.tab_placement = p; } inline void saveTabAlignment(Tab::Alignment a) { *resource.tab_alignment = a; } inline void saveTabRotateVertical(bool r) { resource.tab_rotate_vertical = r; } inline void saveSloppyWindowGrouping(bool s) { resource.sloppy_window_grouping = s; } inline void saveWorkspaceWarping(bool s) { resource.workspace_warping = s; } inline void saveDesktopWheeling(bool s) { resource.desktop_wheeling = s; } inline void iconUpdate(void) { iconmenu->update(); } inline Iconmenu *getIconmenu(void) { return iconmenu; } #ifdef HAVE_STRFTIME inline const char *getStrftimeFormat(void) { return resource.strftime_format.c_str(); } void saveStrftimeFormat(const char *format); #else // !HAVE_STRFTIME inline int getDateFormat(void) { return resource.date_format; } inline void saveDateFormat(int f) { resource.date_format = f; } inline bool isClock24Hour(void) { return resource.clock24hour; } inline void saveClock24Hour(Bool c) { resource.clock24hour = c; } #endif // HAVE_STRFTIME inline Theme::WindowStyle *getWindowStyle(void) { return &theme->getWindowStyle(); } inline Theme::MenuStyle *getMenuStyle(void) { return &theme->getMenuStyle(); } inline Theme::ToolbarStyle *getToolbarStyle(void) { return &theme->getToolbarStyle(); } FluxboxWindow *getIcon(unsigned int index); int addWorkspace(void); int removeLastWorkspace(void); //scroll workspaces void nextWorkspace(const int delta); void prevWorkspace(const int delta); void rightWorkspace(const int delta); void leftWorkspace(const int delta); void removeWorkspaceNames(void); void updateWorkspaceNamesAtom(void); void addWorkspaceName(const char *name); void addNetizen(Netizen *net); void removeNetizen(Window win); void addIcon(FluxboxWindow *win); void removeIcon(FluxboxWindow *win); void getNameOfWorkspace(unsigned int workspace, char **name); void changeWorkspaceID(unsigned int); void sendToWorkspace(unsigned int workspace, FluxboxWindow *win=0, bool changeworkspace=true); void raiseWindows(Window *workspace_stack, int num); void reassociateWindow(FluxboxWindow *window, unsigned int workspace_id, bool ignore_sticky); void prevFocus(int = 0); void nextFocus(int = 0); void raiseFocus(void); void reconfigure(void); void rereadMenu(void); void shutdown(void); void showPosition(int, int); void showGeometry(unsigned int, unsigned int); void hideGeometry(void); void updateNetizenCurrentWorkspace(void); void updateNetizenWorkspaceCount(void); void updateNetizenWindowFocus(void); void updateNetizenWindowAdd(Window, unsigned long); void updateNetizenWindowDel(Window); void updateNetizenConfigNotify(XEvent *); void updateNetizenWindowRaise(Window); void updateNetizenWindowLower(Window); enum { ROWSMARTPLACEMENT = 1, COLSMARTPLACEMENT, CASCADEPLACEMENT, LEFTRIGHT, RIGHTLEFT, TOPBOTTOM, BOTTOMTOP }; enum { LEFTJUSTIFY = 1, RIGHTJUSTIFY, CENTERJUSTIFY }; enum { ROUNDBULLET = 1, TRIANGELBULLET, SQUAERBULLET, NOBULLET }; enum { RESTART = 1, RESTARTOTHER, EXIT, SHUTDOWN, EXECUTE, RECONFIGURE, WINDOWSHADE, WINDOWICONIFY, WINDOWMAXIMIZE, WINDOWCLOSE, WINDOWRAISE, WINDOWLOWER, WINDOWSTICK, WINDOWKILL, SETSTYLE, WINDOWTAB}; // prevFocus/nextFocus option bits enum { CYCLESKIPLOWERTABS = 0x01, CYCLESKIPSTUCK = 0x02, CYCLESKIPSHADED = 0x04, CYCLEDEFAULT = 0x00 }; private: bool doSkipWindow(const FluxboxWindow *w, int options); #ifdef GNOME void initGnomeAtoms(); void updateGnomeClientList(); Window gnome_win; #endif Theme *theme; Bool root_colormap_installed, managed, geom_visible; GC opGC; Pixmap geom_pixmap; Window geom_window; Fluxbox *fluxbox; BImageControl *image_control; Configmenu *configmenu; Iconmenu *iconmenu; Rootmenu *rootmenu; typedef std::list<Rootmenu *> Rootmenus; typedef std::list<Netizen *> Netizens; Rootmenus rootmenuList; Netizens netizenList; Icons iconList; #ifdef SLIT Slit *slit; #endif // SLIT Toolbar *toolbar; Workspace *current_workspace; Workspacemenu *workspacemenu; unsigned int geom_w, geom_h; unsigned long event_mask; typedef std::vector<std::string> WorkspaceNames; typedef std::vector<Workspace *> Workspaces; WorkspaceNames workspaceNames; Workspaces workspacesList; struct ScreenResource { ScreenResource(ResourceManager &rm, const std::string &scrname, const std::string &altscrname); Resource<bool> toolbar_on_top, toolbar_auto_hide, image_dither, opaque_move, full_max, max_over_slit, tab_rotate_vertical, sloppy_window_grouping, workspace_warping, desktop_wheeling, show_window_pos, focus_last, focus_new; Resource<std::string> rootcommand; bool auto_raise, sloppy_focus, semi_sloppy_focus, ordered_dither; Resource<int> workspaces, toolbar_width_percent, edge_snap_threshold, tab_width, tab_height; int placement_policy, row_direction, col_direction; Resource<Tab::Placement> tab_placement; Resource<Tab::Alignment> tab_alignment; #ifdef XINERAMA Resource<int> toolbar_on_head; #endif // XINERAMA Resource<Toolbar::Placement> toolbar_placement; #ifdef SLIT Bool slit_on_top, slit_auto_hide; int slit_placement, slit_direction; #ifdef XINERAMA unsigned int slit_on_head; #endif // XINERAMA #endif // SLIT #ifdef HAVE_STRFTIME std::string strftime_format; #else // !HAVE_STRFTIME Bool clock24hour; int date_format; #endif // HAVE_STRFTIME } resource; void createStyleMenu(Rootmenu *menu, bool newmenu, const char *label, const char *directory); protected: bool parseMenuFile(std::ifstream &, Rootmenu *, int&); bool readDatabaseTexture(char *, char *, FbTk::Texture *, unsigned long); bool readDatabaseColor(char *, char *, FbTk::Color *, unsigned long); void readDatabaseFontSet(char *, char *, XFontSet *); XFontSet createFontSet(char *); void readDatabaseFont(char *, char *, XFontStruct **); void initMenu(void); }; #endif // _SCREEN_HH_