X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fconfig.h;h=5ee071e6540ecba46abf9b3f963f09dc84a2bc83;hb=d0013c0861e29433de10a849032382534c8e1659;hp=45ef015dad2576be2e3aa20436abfacdf31017d9;hpb=94f2b4a7b8b62ed031fe96da4d24b2d5dbb4aded;p=chaz%2Fopenbox diff --git a/openbox/config.h b/openbox/config.h index 45ef015d..5ee071e6 100644 --- a/openbox/config.h +++ b/openbox/config.h @@ -1,54 +1,147 @@ +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- + + config.h for the Openbox window manager + Copyright (c) 2006 Mikael Magnusson + Copyright (c) 2003-2007 Dana Jansens + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + See the COPYING file for a copy of the GNU General Public License. +*/ + #ifndef __config_h #define __config_h +#include "misc.h" +#include "stacking.h" +#include "place.h" +#include "render/render.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; - 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; +/*! Timeout for focusing windows on focus follows mouse, in microseconds */ +extern guint config_focus_delay; +/*! If windows should automatically be raised when they are focused in + focus follows mouse */ +extern gboolean config_focus_raise; +/*! Focus the last focused window, not under the mouse, in follow mouse mode */ +extern gboolean config_focus_last; -/* 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); +extern ObPlacePolicy config_place_policy; -/* Get a config variable's value. Returns FALSE if the value has not been - set. */ -gboolean config_get(char *name, ConfigValueType type, ConfigValue *value); +/*! When true windows' contents are refreshed while they are resized; otherwise + they are not updated until the resize is complete */ +extern gboolean config_resize_redraw; +/*! Divide windows in 4 or 9 areas when doing a resize. The middle will be move + when selecting 9 corners */ +extern gboolean config_resize_four_corners; +/*! show move/resize popups? 0 = no, 1 = always, 2 = only + resizing !1 increments */ +extern gint config_resize_popup_show; +/*! where to show the popup, currently above the window or centered */ +extern gint config_resize_popup_pos; -/* Create a new config definition to add to the config system */ -ConfigDefEntry *config_def_new(char *name, ConfigValueType type); +/*! The stacking layer the dock will reside in */ +extern ObStackingLayer config_dock_layer; +/*! Is the dock floating */ +extern gboolean config_dock_floating; +/*! Don't use a strut for the dock */ +extern gboolean config_dock_nostrut; +/*! 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 microseconds to wait before hiding the dock */ +extern guint config_dock_hide_delay; +/*! The number of microseconds to wait before showing the dock */ +extern guint config_dock_show_delay; +/*! The mouse button to be used to move dock apps */ +extern guint config_dock_app_move_button; +/*! The modifiers to be used with the button to move dock apps */ +extern guint config_dock_app_move_modifiers; -/* Add a value to a String type config definition */ -gboolean config_def_add_value(ConfigDefEntry *entry, char *value); +/*! The name of the theme */ +extern gchar *config_theme; -/* 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); +/*! 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; -void config_parse(); +/*! The font for the active window's title */ +extern RrFont *config_font_activewindow; +/*! The font for inactive windows' titles */ +extern RrFont *config_font_inactivewindow; +/*! The font for menu titles */ +extern RrFont *config_font_menutitle; +/*! The font for menu items */ +extern RrFont *config_font_menuitem; + +/*! The number of desktops */ +extern gint config_desktops_num; +/*! Desktop to start on, put 5 to start in the center of a 3x3 grid */ +extern guint config_screen_firstdesk; +/*! Names for the desktops */ +extern GSList *config_desktops_names; + +/*! The keycode of the key combo which resets the keybaord chains */ +extern guint config_keyboard_reset_keycode; +/*! The modifiers of the key combo which resets the keybaord chains */ +extern guint config_keyboard_reset_state; + +/*! 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; + +/*! 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 */ +extern gboolean config_menu_middle; +/*! delay before opening a submenu */ +extern guint config_submenu_show_delay; +/*! show icons in client_list_menu */ +extern gboolean config_menu_client_list_icons; +/*! User-specified menu files */ +extern GSList *config_menu_files; +/*! Per app settings */ +extern GSList *config_per_app_settings; + +void config_startup(struct _ObParseInst *i); +void config_shutdown(); #endif