X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fconfig.h;h=98a5340bea32e121c9906ccfe847e50141013949;hb=c34915ae8d49f61426912ef332e8097be516bdd3;hp=7366e95f041fba453d55628f42585a52be915d08;hpb=3cc402bd567974c99edf8e3334d3c48103d06fc7;p=chaz%2Fopenbox diff --git a/openbox/config.h b/openbox/config.h index 7366e95f..98a5340b 100644 --- a/openbox/config.h +++ b/openbox/config.h @@ -1,57 +1,81 @@ #ifndef __config_h #define __config_h +#include "misc.h" +#include "stacking.h" + #include -typedef enum { - Config_String, - Config_Integer -} ConfigValueType; - -typedef union { - char *string; - int integer; -} ConfigValue; - -typedef struct { - char *name; - ConfigValueType type; - ConfigValue value; -} ConfigEntry; - -typedef struct { - char *name; - char *descriptive_name; /* user friendly name */ - char *long_description; /* text description of option */ - ConfigValueType type; - /* if it is a string type optionally provide a list of valid strings */ - gboolean hasList; - GSList *values; -} ConfigDefEntry; - -void config_startup(); -void config_shutdown(); +struct _ObParseInst; + +/*! Should new windows be focused */ +extern gboolean config_focus_new; +/*! Focus windows when the mouse enters them */ +extern gboolean config_focus_follow; +/*! Focus the last focused window as a fallback */ +extern gboolean config_focus_last; +/*! Focus the last focused window as a fallback when switching desktops */ +extern gboolean config_focus_last_on_desktop; +/*! Show a popup dialog while cycling focus */ +extern gboolean config_focus_popup; +/*! Show a popup dialog while cycling desktops */ +extern gboolean config_desktop_popup; +/*! The number of slits to create + extern int config_slit_number;*/ +/*! When true windows' contents are refreshed while they are resized; otherwise + they are not updated until the resize is complete */ +extern gboolean config_redraw_resize; + +/*! The stacking layer the dock will reside in */ +extern ObStackingLayer config_dock_layer; +/*! Is the dock floating */ +extern gboolean config_dock_floating; +/*! Where to place the dock if not floating */ +extern ObDirection config_dock_pos; +/*! If config_dock_floating, this is the top-left corner's + position */ +extern gint config_dock_x; +/*! If config_dock_floating, this is the top-left corner's + position */ +extern gint config_dock_y; +/*! Whether the dock places the dockapps in it horizontally or vertically */ +extern ObOrientation config_dock_orient; +/*! Whether to auto-hide the dock when the pointer is not over it */ +extern gboolean config_dock_hide; +/*! The number of milliseconds to wait before hiding the dock */ +extern guint config_dock_hide_timeout; -/* Set a config variable's value. The variable must have already been defined - with a call to config_def_set */ -gboolean config_set(char *name, ConfigValueType type, ConfigValue value); +/* The name of the theme */ +char *config_theme; -/* Get a config variable's value. Returns FALSE if the value has not been - set. */ -gboolean config_get(char *name, ConfigValueType type, ConfigValue *value); +/* Titlebar button layout */ +gchar *config_title_layout; -/* Create a new config definition to add to the config system */ -ConfigDefEntry *config_def_new(char *name, ConfigValueType type, - char *descriptive_name, char *long_description); +/*! The number of desktops */ +extern int config_desktops_num; +/*! Names for the desktops */ +extern GSList *config_desktops_names; -/* Add a value to a String type config definition */ -gboolean config_def_add_value(ConfigDefEntry *entry, char *value); +/*! The keycode of the key combo which resets the keybaord chains */ +guint config_keyboard_reset_keycode; +/*! The modifiers of the key combo which resets the keybaord chains */ +guint config_keyboard_reset_state; -/* Sets up the definition in the config system, Don't free or touch the entry - after setting it with this. It is invalidated even if the function returns - FALSE. */ -gboolean config_def_set(ConfigDefEntry *entry); +/*! Number of pixels a drag must go before being considered a drag */ +extern gint config_mouse_threshold; +/*! Number of milliseconds within which 2 clicks must occur to be a + double-click */ +extern gint config_mouse_dclicktime; -void config_parse(); +/*! Number of pixels to resist while crossing another window's edge */ +gint config_resist_win; +/*! Number of pixels to resist while crossing a screen's edge */ +gint config_resist_edge; + +/*! User-specified path to the menu file */ +extern gchar *config_menu_path; + +void config_startup(struct _ObParseInst *i); +void config_shutdown(); #endif