8 #define DESKTOP_ALL (0xffffffff)
10 /*! The number of available desktops */
11 extern guint screen_num_desktops
;
12 /*! The current desktop */
13 extern guint screen_desktop
;
14 /*! The size of the screen */
15 extern Size screen_physical_size
;
16 /*! Are we in showing-desktop mode? */
17 extern gboolean screen_showing_desktop
;
19 /*! Orientation of the desktops */
25 typedef struct DesktopLayout
{
31 extern DesktopLayout screen_desktop_layout
;
33 /*! An array of gchar*'s which are desktop names in UTF-8 format */
34 extern GPtrArray
*screen_desktop_names
;
36 /*! Take over the screen, set the basic hints on it claming it as ours */
37 gboolean
screen_annex();
39 /*! Once the screen is ours, set up its initial state */
40 void screen_startup();
42 void screen_shutdown();
44 /*! Figure out the new size of the screen and adjust stuff for it */
47 /*! Change the number of available desktops */
48 void screen_set_num_desktops(guint num
);
49 /*! Change the current desktop */
50 void screen_set_desktop(guint num
);
52 /*! Shows and focuses the desktop and hides all the client windows, or
53 returns to the normal state, showing client windows. */
54 void screen_show_desktop(gboolean show
);
56 /*! Updates the desktop layout from the root property if available */
57 void screen_update_layout();
59 /*! Get desktop names from the root window property */
60 void screen_update_desktop_names();
62 /*! Installs or uninstalls a colormap for a client. If client is NULL, then
63 it handles the root colormap. */
64 void screen_install_colormap(struct Client
*client
, gboolean install
);
66 void screen_update_struts();
68 Rect
*screen_area(guint desktop
);
70 Strut
*screen_strut(guint desktop
);