Merge branch 'work' into wip/mikabox
[mikachu/openbox.git] / openbox / config.h
1 /* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*-
2
3    config.h for the Openbox window manager
4    Copyright (c) 2006        Mikael Magnusson
5    Copyright (c) 2003-2007   Dana Jansens
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    See the COPYING file for a copy of the GNU General Public License.
18 */
19
20 #ifndef __config_h
21 #define __config_h
22
23 #include "misc.h"
24 #include "stacking.h"
25 #include "place.h"
26 #include "client.h"
27 #include "geom.h"
28 #include "moveresize.h"
29 #include "obrender/render.h"
30 #include "obt/xml.h"
31
32 #include <glib.h>
33
34 typedef struct _ObAppSettings ObAppSettings;
35
36 struct _ObAppSettings
37 {
38     GPatternSpec *class;
39     GPatternSpec *name;
40     GPatternSpec *role;
41     GPatternSpec *group_class;
42     GPatternSpec *group_name;
43     GPatternSpec *title;
44     ObClientType  type;
45
46     GravityPoint position;
47     gboolean pos_given;
48     gboolean pos_force;
49
50     gint width_num;
51     gint width_denom;
52     gint height_num;
53     gint height_denom;
54
55     guint desktop;
56     gint shade;
57     gint decor;
58     gint focus;
59     ObPlaceMonitor monitor_type;
60     gint monitor;
61     gint iconic;
62     gint skip_pager;
63     gint skip_taskbar;
64     gint max_horz;
65     gint max_vert;
66     gint fullscreen;
67
68     gint layer;
69 };
70
71 /*! Should new windows be focused */
72 extern gboolean config_focus_new;
73 /*! Focus windows when the mouse enters them */
74 extern gboolean config_focus_follow;
75 /*! Timeout for focusing windows on focus follows mouse, in milliseconds */
76 extern guint    config_focus_delay;
77 /*! If windows should automatically be raised when they are focused in
78  focus follows mouse */
79 extern gboolean config_focus_raise;
80 /*! Focus the last focused window, not under the mouse, in follow mouse mode */
81 extern gboolean config_focus_last;
82 /*! Try keep focus on the window under the mouse when the mouse is not moving
83  */
84 extern gboolean config_focus_under_mouse;
85 /*! Remove focus from windows when the mouse leaves them
86  */
87 extern gboolean config_unfocus_leave;
88 /*! Weight of distance part of score for directional switching */
89 extern guint config_directional_distance_weight;
90 /*! Weight of angle part of score for directional switching */
91 extern guint config_directional_angle_weight;
92
93 /*! The algorithm to use for placing new windows */
94 extern ObPlacePolicy config_place_policy;
95 /*! Place windows in the center of the free area */
96 extern gboolean config_place_center;
97 /*! Place windows on the active monitor (unless they are part of an application
98   already on another monitor) */
99 extern ObPlaceMonitor config_place_monitor;
100
101 /*! Place dialogs and stuff on this monitor.  Index starts at 1.  If this is
102   0, then use the config_primary_monitor instead. */
103 extern guint config_primary_monitor_index;
104 /*! Where to place dialogs and stuff if it is not specified by index. */
105 extern ObPlaceMonitor config_primary_monitor;
106
107 /*! User-specified margins around the edge of the screen(s) */
108 extern StrutPartial config_margins;
109
110 /*! When true windows' contents are refreshed while they are resized; otherwise
111   they are not updated until the resize is complete */
112 extern gboolean config_resize_redraw;
113 /*! show move/resize popups? 0 = no, 1 = always, 2 = only
114   resizing !1 increments */
115 extern gint config_resize_popup_show;
116 /*! where to show the resize popup */
117 extern ObResizePopupPos config_resize_popup_pos;
118 /*! where to place the popup if it's in a fixed position */
119 extern GravityPoint config_resize_popup_fixed;
120
121 /*! The stacking layer the dock will reside in */
122 extern ObStackingLayer config_dock_layer;
123 /*! Is the dock floating */
124 extern gboolean config_dock_floating;
125 /*! Don't use a strut for the dock */
126 extern gboolean config_dock_nostrut;
127 /*! Where to place the dock if not floating */
128 extern ObDirection config_dock_pos;
129 /*! If config_dock_floating, this is the top-left corner's
130   position */
131 extern gint config_dock_x;
132 /*! If config_dock_floating, this is the top-left corner's
133   position */
134 extern gint config_dock_y;
135 /*! Whether the dock places the dockapps in it horizontally or vertically */
136 extern ObOrientation config_dock_orient;
137 /*! Whether to auto-hide the dock when the pointer is not over it */
138 extern gboolean config_dock_hide;
139 /*! The number of milliseconds to wait before hiding the dock */
140 extern guint config_dock_hide_delay;
141 /*! The number of milliseconds to wait before showing the dock */
142 extern guint config_dock_show_delay;
143 /*! The mouse button to be used to move dock apps */
144 extern guint config_dock_app_move_button;
145 /*! The modifiers to be used with the button to move dock apps */
146 extern guint config_dock_app_move_modifiers;
147
148 /*! The name of the theme */
149 extern gchar *config_theme;
150
151 /*! Show the one-pixel border after toggleDecor */
152 extern gboolean config_theme_keepborder;
153 /*! Titlebar button layout */
154 extern gchar *config_title_layout;
155 /*! Animate windows iconifying and restoring */
156 extern gboolean config_animate_iconify;
157 /*! Size of icons in focus switching dialogs */
158 extern guint config_theme_window_list_icon_size;
159
160 /*! The font for the active window's title */
161 extern RrFont *config_font_activewindow;
162 /*! The font for inactive windows' titles */
163 extern RrFont *config_font_inactivewindow;
164 /*! The font for menu titles */
165 extern RrFont *config_font_menutitle;
166 /*! The font for menu items */
167 extern RrFont *config_font_menuitem;
168 /*! The font for on-screen-displays/popups' active text */
169 extern RrFont *config_font_activeosd;
170 /*! The font for on-screen-displays/popups' inactive text */
171 extern RrFont *config_font_inactiveosd;
172
173 /*! The number of desktops */
174 extern guint config_desktops_num;
175 /*! Desktop to start on, put 5 to start in the center of a 3x3 grid */
176 extern guint config_screen_firstdesk;
177 /*! Emulate xinerama by dividing screen in two halves, left and right. */
178 extern gboolean config_emulate_xinerama;
179 /*! Names for the desktops */
180 extern GSList *config_desktops_names;
181 /*! Amount of time to show the desktop switch dialog */
182 extern guint config_desktop_popup_time;
183
184 /*! The keycode of the key combo which resets the keybaord chains */
185 extern guint config_keyboard_reset_keycode;
186 /*! The modifiers of the key combo which resets the keybaord chains */
187 extern guint config_keyboard_reset_state;
188 /*! Reload the keyboard bindings when the mapping changes */
189 extern gboolean config_keyboard_rebind_on_mapping_notify;
190
191 /*! Number of pixels a drag must go before being considered a drag */
192 extern gint config_mouse_threshold;
193 /*! Number of milliseconds within which 2 clicks must occur to be a
194   double-click */
195 extern gint config_mouse_dclicktime;
196 /*! Number of milliseconds that the mouse has to be on the screen edge before
197   a screen edge event is triggered */
198 extern gint config_mouse_screenedgetime;
199 /*! When TRUE, the mouse is warped to the other side of the desktop after
200   switching desktops from bumping the screen edge */
201 extern gboolean config_mouse_screenedgewarp;
202
203 /*! Number of pixels to resist while crossing another window's edge */
204 extern gint config_resist_win;
205 /*! Number of pixels to resist while crossing a screen's edge */
206 extern gint config_resist_edge;
207
208 /*! Delay for hiding menu when opening in milliseconds */
209 extern guint    config_menu_hide_delay;
210 /*! Center menus vertically about the parent entry */
211 extern gboolean config_menu_middle;
212 /*! Delay before opening a submenu in milliseconds */
213 extern guint    config_submenu_show_delay;
214 /*! Delay before closing a submenu in milliseconds */
215 extern guint    config_submenu_hide_delay;
216 /*! Show manage desktops in client_list_menu */
217 extern gboolean config_menu_manage_desktops;
218 /*! Load & show icons in user-defined menus */
219 extern gboolean config_menu_show_icons;
220 /*! User-specified menu files */
221 extern GSList *config_menu_files;
222 /*! Per app settings */
223 extern GSList *config_per_app_settings;
224
225 void config_startup(ObtXmlInst *i);
226 void config_shutdown(void);
227
228 /*! Create an ObAppSettings structure with the default values */
229 ObAppSettings* config_create_app_settings(void);
230 /*! Copies any settings in src to dest, if they are their default value in
231   src. */
232 void config_app_settings_copy_non_defaults(const ObAppSettings *src,
233                                            ObAppSettings *dest);
234 /*! Parses an x geometry style position, with some extensions like ratios
235   and percentages */
236 void config_parse_gravity_coord(xmlNodePtr node, GravityCoord *c);
237 /*! Parses a rational number or percentage into num and denom */
238 void config_parse_relative_number(gchar *s, gint *num, gint *denom);
239
240 #endif