X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fconfig.h;h=42bf35346770964de08b3774ce3c75d36174ad2b;hb=fc32204f3c1733b289d7f03a15f9f0a568369989;hp=41cf74823afb4a1fbf36f56ef729fc1878ab6c6b;hpb=7ffa091d5b464ce508023c3b5e5bc50a36be53fb;p=chaz%2Fopenbox diff --git a/openbox/config.h b/openbox/config.h index 41cf7482..42bf3534 100644 --- a/openbox/config.h +++ b/openbox/config.h @@ -30,15 +30,19 @@ struct _ObParseInst; +typedef struct _ObAppSettings ObAppSettings; + struct _ObAppSettings { - gchar *class; - gchar *name; - gchar *role; + GPatternSpec *class; + GPatternSpec *name; + GPatternSpec *role; Point position; gboolean center_x; gboolean center_y; + gboolean opposite_x; + gboolean opposite_y; gboolean pos_given; guint desktop; @@ -67,8 +71,16 @@ extern guint config_focus_delay; extern gboolean config_focus_raise; /*! Focus the last focused window, not under the mouse, in follow mouse mode */ extern gboolean config_focus_last; +/*! Try keep focus on the window under the mouse when the mouse is not moving + */ +extern gboolean config_focus_under_mouse; extern ObPlacePolicy config_place_policy; +/*! Place windows in the center of the free area */ +extern gboolean config_place_center; + +/*! User-specified margins around the edge of the screen(s) */ +extern StrutPartial config_margins; /*! When true windows' contents are refreshed while they are resized; otherwise they are not updated until the resize is complete */ @@ -111,8 +123,6 @@ extern gchar *config_theme; /*! Show the one-pixel border after toggleDecor */ extern gboolean config_theme_keepborder; -/*! Hide window frame buttons that the window doesn't allow */ -extern gboolean config_theme_hidedisabled; /*! Titlebar button layout */ extern gchar *config_title_layout; /*! Animate windows iconifying and restoring */ @@ -146,16 +156,15 @@ extern gint config_mouse_threshold; /*! Number of milliseconds within which 2 clicks must occur to be a double-click */ extern gint config_mouse_dclicktime; +/*! Number of milliseconds that the mouse has to be on the screen edge before + a screen edge event is triggered */ +extern gint config_mouse_screenedgetime; /*! Number of pixels to resist while crossing another window's edge */ extern gint config_resist_win; /*! Number of pixels to resist while crossing a screen's edge */ extern gint config_resist_edge; -/*! Should windows resist edges at layers below */ -extern gboolean config_resist_layers_below; -/*! Warp near edge on menu? */ -extern gboolean config_menu_warppointer; /*! delay for hiding menu when opening */ extern guint config_menu_hide_delay; /*! Center menus vertically about the parent entry */ @@ -172,4 +181,12 @@ extern GSList *config_per_app_settings; void config_startup(struct _ObParseInst *i); void config_shutdown(); +/*! Create an ObAppSettings structure with the default values */ +ObAppSettings* config_create_app_settings(); +/*! Copies any settings in src to dest, if they are their default value in + src. */ +void config_app_settings_copy_non_defaults(const ObAppSettings *src, + ObAppSettings *dest); + + #endif