X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fconfig.h;h=42bf35346770964de08b3774ce3c75d36174ad2b;hb=bfb0c916718cd6f68ef100841a625b06602f616b;hp=e6a441b0b54b0836dcf3f860fe9d022843f96cec;hpb=4e590eba236c587caff22d8cfc3a8fc0332cb206;p=chaz%2Fopenbox diff --git a/openbox/config.h b/openbox/config.h index e6a441b0..42bf3534 100644 --- a/openbox/config.h +++ b/openbox/config.h @@ -23,12 +23,43 @@ #include "misc.h" #include "stacking.h" #include "place.h" +#include "geom.h" #include "render/render.h" #include struct _ObParseInst; +typedef struct _ObAppSettings ObAppSettings; + +struct _ObAppSettings +{ + 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; + gint shade; + gint decor; + gint focus; + gint monitor; + gint iconic; + gint skip_pager; + gint skip_taskbar; + gint max_horz; + gint max_vert; + gint fullscreen; + + gint layer; +}; + /*! Should new windows be focused */ extern gboolean config_focus_new; /*! Focus windows when the mouse enters them */ @@ -40,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 */ @@ -84,10 +123,10 @@ 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 */ +extern gboolean config_animate_iconify; /*! The font for the active window's title */ extern RrFont *config_font_activewindow; @@ -117,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 */ @@ -143,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