2 * config.c - configuration management
4 * Copyright © 2007-2008 Julien Danjou <julien@danjou.info>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 * @defgroup ui_callback User Interface Callbacks
26 #include <X11/keysym.h>
28 #include "statusbar.h"
35 #include "defconfig.h"
36 #include "layouts/tile.h"
38 #define AWESOME_CONFIG_FILE ".awesomerc"
40 extern AwesomeConf globalconf
;
42 /** Link a name to a key symbol */
49 /** Link a name to a mouse button symbol */
56 extern const NameFuncLink UicbList
[];
57 extern const NameFuncLink WidgetList
[];
58 extern const NameFuncLink LayoutsList
[];
62 get_numlockmask(Display
*disp
)
64 XModifierKeymap
*modmap
;
65 unsigned int mask
= 0;
68 modmap
= XGetModifierMapping(disp
);
69 for(i
= 0; i
< 8; i
++)
70 for(j
= 0; j
< modmap
->max_keypermod
; j
++)
71 if(modmap
->modifiermap
[i
* modmap
->max_keypermod
+ j
]
72 == XKeysymToKeycode(disp
, XK_Num_Lock
))
75 XFreeModifiermap(modmap
);
80 /** Lookup for a key mask from its name
81 * \param keyname Key name
82 * \return Key mask or 0 if not found
85 key_mask_lookup(const char *keyname
)
87 /** List of keyname and corresponding X11 mask codes */
88 static const KeyMod KeyModList
[] =
92 {"Control", ControlMask
},
103 for(i
= 0; KeyModList
[i
].name
; i
++)
104 if(!a_strcmp(keyname
, KeyModList
[i
].name
))
105 return KeyModList
[i
].keysym
;
110 /** Lookup for a mouse button from its name
111 * \param button Mouse button name
112 * \return Mouse button or 0 if not found
115 mouse_button_lookup(const char *button
)
117 /** List of button name and corresponding X11 mask codes */
118 static const MouseButton MouseButtonList
[] =
130 for(i
= 0; MouseButtonList
[i
].name
; i
++)
131 if(!a_strcmp(button
, MouseButtonList
[i
].name
))
132 return MouseButtonList
[i
].button
;
138 parse_mouse_bindings(cfg_t
* cfg
, const char *secname
, Bool handle_arg
)
142 Button
*b
= NULL
, *head
= NULL
;
144 /* Mouse: layout click bindings */
145 for(i
= 0; i
< cfg_size(cfg
, secname
); i
++)
147 /* init first elem */
149 head
= b
= p_new(Button
, 1);
151 cfgsectmp
= cfg_getnsec(cfg
, secname
, i
);
152 for(j
= 0; j
< cfg_size(cfgsectmp
, "modkey"); j
++)
153 b
->mod
|= key_mask_lookup(cfg_getnstr(cfgsectmp
, "modkey", j
));
154 b
->button
= mouse_button_lookup(cfg_getstr(cfgsectmp
, "button"));
155 b
->func
= name_func_lookup(cfg_getstr(cfgsectmp
, "command"), UicbList
);
157 warn("unknown command %s\n", cfg_getstr(cfgsectmp
, "command"));
159 b
->arg
= a_strdup(cfg_getstr(cfgsectmp
, "arg"));
163 /* switch to next elem or finalize the list */
164 if(i
< cfg_size(cfg
, secname
) - 1)
166 b
->next
= p_new(Button
, 1);
178 set_key_info(Key
*key
, cfg_t
*cfg
)
182 for(j
= 0; j
< cfg_size(cfg
, "modkey"); j
++)
183 key
->mod
|= key_mask_lookup(cfg_getnstr(cfg
, "modkey", j
));
184 key
->func
= name_func_lookup(cfg_getstr(cfg
, "command"), UicbList
);
186 warn("unknown command %s\n", cfg_getstr(cfg
, "command"));
191 section_keys(cfg_t
*cfg_keys
)
194 unsigned int i
, j
, numkeys
;
198 for(i
= 0; i
< cfg_size(cfg_keys
, "key"); i
++)
201 key
= head
= p_new(Key
, 1);
204 key
->next
= p_new(Key
, 1);
207 cfgkeytmp
= cfg_getnsec(cfg_keys
, "key", i
);
208 set_key_info(key
, cfgkeytmp
);
209 key
->keysym
= XStringToKeysym(cfg_getstr(cfgkeytmp
, "key"));
210 key
->arg
= a_strdup(cfg_getstr(cfgkeytmp
, "arg"));
213 for(i
= 0; i
< cfg_size(cfg_keys
, "keylist"); i
++)
215 cfgkeytmp
= cfg_getnsec(cfg_keys
, "keylist", i
);
216 numkeys
= cfg_size(cfgkeytmp
, "keylist");
217 if (numkeys
!= cfg_size(cfgkeytmp
, "arglist"))
219 warn("number of keys != number of args in keylist");
222 for(j
=0; j
< numkeys
; j
++)
231 key
->next
= p_new(Key
, 1);
234 set_key_info(key
, cfgkeytmp
);
235 key
->keysym
= XStringToKeysym(cfg_getnstr(cfgkeytmp
, "keylist", j
));
236 key
->arg
= a_strdup(cfg_getnstr(cfgkeytmp
, "arglist", j
));
239 key
->next
= p_new(Key
, 1);
251 cmp_widget_cfg(const void *a
, const void *b
)
253 if (((cfg_t
*)a
)->line
< ((cfg_t
*)b
)->line
)
256 if (((cfg_t
*)a
)->line
> ((cfg_t
*)b
)->line
)
263 create_widgets(cfg_t
* cfg_statusbar
, Statusbar
*statusbar
)
265 cfg_t
* widgets
, *wptr
;
266 Widget
*widget
= NULL
;
267 unsigned int i
, j
, numwidgets
= 0;
268 WidgetConstructor
*widget_new
;
270 for(i
= 0; WidgetList
[i
].name
; i
++)
271 numwidgets
+= cfg_size(cfg_statusbar
, WidgetList
[i
].name
);
273 widgets
= p_new(cfg_t
, numwidgets
);
276 for(i
= 0; WidgetList
[i
].name
; i
++)
277 for (j
= 0; j
< cfg_size(cfg_statusbar
, WidgetList
[i
].name
); j
++)
280 cfg_getnsec(cfg_statusbar
, WidgetList
[i
].name
, j
),
285 qsort(widgets
, numwidgets
, sizeof(cfg_t
), cmp_widget_cfg
);
287 for (i
= 0; i
< numwidgets
; i
++)
290 widget_new
= name_func_lookup(cfg_name(wptr
), WidgetList
);
294 statusbar
->widgets
= widget
= widget_new(statusbar
, wptr
);
297 widget
->next
= widget_new(statusbar
, wptr
);
298 widget
= widget
->next
;
300 widget
->buttons
= parse_mouse_bindings(wptr
, "mouse", a_strcmp(cfg_name(wptr
), "taglist"));
303 warn("Ignoring unknown widget: %s.\n", cfg_name(widgets
+ i
));
308 config_parse_screen(cfg_t
*cfg
, int screen
)
312 Layout
*layout
= NULL
;
314 Statusbar
*statusbar
= NULL
;
315 cfg_t
*cfg_general
, *cfg_colors
, *cfg_screen
, *cfg_tags
,
316 *cfg_layouts
, *cfg_padding
, *cfgsectmp
;
317 VirtScreen
*virtscreen
= &globalconf
.screens
[screen
];
319 int phys_screen
= get_phys_screen(screen
);
321 snprintf(buf
, sizeof(buf
), "%d", screen
);
322 cfg_screen
= cfg_gettsec(cfg
, "screen", buf
);
324 cfg_screen
= cfg_getsec(cfg
, "screen");
328 warn("parsing configuration file failed, no screen section found\n");
329 cfg_parse_buf(cfg
, AWESOME_DEFAULT_CONFIG
);
330 cfg_screen
= cfg_getsec(cfg
, "screen");
333 /* get screen specific sections */
334 cfg_tags
= cfg_getsec(cfg_screen
, "tags");
335 cfg_colors
= cfg_getsec(cfg_screen
, "colors");
336 cfg_general
= cfg_getsec(cfg_screen
, "general");
337 cfg_layouts
= cfg_getsec(cfg_screen
, "layouts");
338 cfg_padding
= cfg_getsec(cfg_screen
, "padding");
341 /* General section */
342 virtscreen
->borderpx
= cfg_getint(cfg_general
, "border");
343 virtscreen
->snap
= cfg_getint(cfg_general
, "snap");
344 virtscreen
->resize_hints
= cfg_getbool(cfg_general
, "resize_hints");
345 virtscreen
->opacity_unfocused
= cfg_getint(cfg_general
, "opacity_unfocused");
346 virtscreen
->focus_move_pointer
= cfg_getbool(cfg_general
, "focus_move_pointer");
347 virtscreen
->allow_lower_floats
= cfg_getbool(cfg_general
, "allow_lower_floats");
348 virtscreen
->sloppy_focus
= cfg_getbool(cfg_general
, "sloppy_focus");
349 virtscreen
->new_become_master
= cfg_getbool(cfg_general
, "new_become_master");
350 virtscreen
->new_get_focus
= cfg_getbool(cfg_general
, "new_get_focus");
351 virtscreen
->font
= XftFontOpenName(globalconf
.display
,
353 cfg_getstr(cfg_general
, "font"));
354 if(!virtscreen
->font
)
355 eprint("awesome: cannot init font\n");
358 virtscreen
->colors_normal
[ColBorder
] = initxcolor(phys_screen
,
359 cfg_getstr(cfg_colors
, "normal_border"));
360 virtscreen
->colors_normal
[ColBG
] = initxcolor(phys_screen
,
361 cfg_getstr(cfg_colors
, "normal_bg"));
362 virtscreen
->colors_normal
[ColFG
] = initxcolor(phys_screen
,
363 cfg_getstr(cfg_colors
, "normal_fg"));
364 virtscreen
->colors_selected
[ColBorder
] = initxcolor(phys_screen
,
365 cfg_getstr(cfg_colors
, "focus_border"));
366 virtscreen
->colors_selected
[ColBG
] = initxcolor(phys_screen
,
367 cfg_getstr(cfg_colors
, "focus_bg"));
368 virtscreen
->colors_selected
[ColFG
] = initxcolor(phys_screen
,
369 cfg_getstr(cfg_colors
, "focus_fg"));
370 virtscreen
->colors_urgent
[ColBG
] = initxcolor(phys_screen
,
371 cfg_getstr(cfg_colors
, "urgent_bg"));
372 virtscreen
->colors_urgent
[ColFG
] = initxcolor(phys_screen
,
373 cfg_getstr(cfg_colors
, "urgent_fg"));
377 if(cfg_size(cfg_screen
, "statusbar"))
379 virtscreen
->statusbar
= statusbar
= p_new(Statusbar
, 1);
380 for(i
= 0; i
< cfg_size(cfg_screen
, "statusbar"); i
++)
382 cfgsectmp
= cfg_getnsec(cfg_screen
, "statusbar", i
);
383 statusbar
->position
= statusbar
->dposition
=
384 statusbar_get_position_from_str(cfg_getstr(cfgsectmp
, "position"));
385 statusbar
->height
= cfg_getint(cfgsectmp
, "height");
386 statusbar
->width
= cfg_getint(cfgsectmp
, "width");
387 statusbar
->name
= a_strdup(cfg_title(cfgsectmp
));
388 create_widgets(cfgsectmp
, statusbar
);
390 if(i
< cfg_size(cfg_screen
, "statusbar") - 1)
391 statusbar
= statusbar
->next
= p_new(Statusbar
, 1);
396 virtscreen
->layouts
= layout
= p_new(Layout
, 1);
397 if(cfg_size(cfg_layouts
, "layout"))
399 for(i
= 0; i
< cfg_size(cfg_layouts
, "layout"); i
++)
401 cfgsectmp
= cfg_getnsec(cfg_layouts
, "layout", i
);
402 layout
->arrange
= name_func_lookup(cfg_title(cfgsectmp
), LayoutsList
);
405 warn("unknown layout %s in configuration file\n", cfg_title(cfgsectmp
));
406 layout
->image
= NULL
;
409 layout
->image
= a_strdup(cfg_getstr(cfgsectmp
, "image"));
411 if(i
< cfg_size(cfg_layouts
, "layout") - 1)
413 layout
->next
= p_new(Layout
, 1);
414 layout
->next
->prev
= layout
;
415 layout
= layout
->next
;
419 virtscreen
->layouts
->prev
= layout
;
423 warn("no default layout available\n");
424 layout
->arrange
= layout_tile
;
428 virtscreen
->tags
= tag
= p_new(Tag
, 1);
429 if(cfg_size(cfg_tags
, "tag"))
430 for(i
= 0; i
< cfg_size(cfg_tags
, "tag"); i
++)
432 cfgsectmp
= cfg_getnsec(cfg_tags
, "tag", i
);
433 tag
->name
= a_strdup(cfg_title(cfgsectmp
));
434 tag
->selected
= False
;
435 tag
->was_selected
= False
;
436 tmp
= cfg_getstr(cfgsectmp
, "layout");
437 for(layout
= virtscreen
->layouts
;
438 layout
&& layout
->arrange
!= name_func_lookup(tmp
, LayoutsList
); layout
= layout
->next
);
440 tag
->layout
= virtscreen
->layouts
;
442 tag
->layout
= layout
;
443 tag
->mwfact
= cfg_getfloat(cfgsectmp
, "mwfact");
444 tag
->nmaster
= cfg_getint(cfgsectmp
, "nmaster");
445 tag
->ncol
= cfg_getint(cfgsectmp
, "ncol");
447 if(i
< cfg_size(cfg_tags
, "tag") - 1)
448 tag
= tag
->next
= p_new(Tag
, 1);
454 warn("fatal: no tags found in configuration file\n");
455 tag
->name
= a_strdup("default");
456 tag
->layout
= virtscreen
->layouts
;
462 ewmh_update_net_numbers_of_desktop(phys_screen
);
463 ewmh_update_net_current_desktop(phys_screen
);
464 ewmh_update_net_desktop_names(phys_screen
);
466 /* select first tag by default */
467 virtscreen
->tags
[0].selected
= True
;
468 virtscreen
->tags
[0].was_selected
= True
;
471 virtscreen
->padding
.top
= cfg_getint(cfg_padding
, "top");
472 virtscreen
->padding
.bottom
= cfg_getint(cfg_padding
, "bottom");
473 virtscreen
->padding
.left
= cfg_getint(cfg_padding
, "left");
474 virtscreen
->padding
.right
= cfg_getint(cfg_padding
, "right");
477 /** Parse configuration file and initialize some stuff
478 * \param confpatharg Path to configuration file
481 config_parse(const char *confpatharg
)
483 static cfg_opt_t general_opts
[] =
485 CFG_INT((char *) "border", 1, CFGF_NONE
),
486 CFG_INT((char *) "snap", 8, CFGF_NONE
),
487 CFG_BOOL((char *) "resize_hints", cfg_true
, CFGF_NONE
),
488 CFG_INT((char *) "opacity_unfocused", 100, CFGF_NONE
),
489 CFG_BOOL((char *) "focus_move_pointer", cfg_false
, CFGF_NONE
),
490 CFG_BOOL((char *) "allow_lower_floats", cfg_false
, CFGF_NONE
),
491 CFG_BOOL((char *) "sloppy_focus", cfg_true
, CFGF_NONE
),
492 CFG_BOOL((char *) "new_become_master", cfg_true
, CFGF_NONE
),
493 CFG_BOOL((char *) "new_get_focus", cfg_true
, CFGF_NONE
),
494 CFG_STR((char *) "font", (char *) "mono-12", CFGF_NONE
),
497 static cfg_opt_t colors_opts
[] =
499 CFG_STR((char *) "normal_border", (char *) "#111111", CFGF_NONE
),
500 CFG_STR((char *) "normal_bg", (char *) "#111111", CFGF_NONE
),
501 CFG_STR((char *) "normal_fg", (char *) "#eeeeee", CFGF_NONE
),
502 CFG_STR((char *) "focus_border", (char *) "#6666ff", CFGF_NONE
),
503 CFG_STR((char *) "focus_bg", (char *) "#6666ff", CFGF_NONE
),
504 CFG_STR((char *) "focus_fg", (char *) "#ffffff", CFGF_NONE
),
505 CFG_STR((char *) "urgent_bg", (char *) "#ff0000", CFGF_NONE
),
506 CFG_STR((char *) "urgent_fg", (char *) "#ffffff", CFGF_NONE
),
507 CFG_STR((char *) "tab_border", (char *) "#ff0000", CFGF_NONE
),
510 static cfg_opt_t mouse_taglist_opts
[] =
512 CFG_STR_LIST((char *) "modkey", (char *) "{}", CFGF_NONE
),
513 CFG_STR((char *) "button", (char *) "None", CFGF_NONE
),
514 CFG_STR((char *) "command", (char *) "", CFGF_NONE
),
517 static cfg_opt_t mouse_generic_opts
[] =
519 CFG_STR_LIST((char *) "modkey", (char *) "{}", CFGF_NONE
),
520 CFG_STR((char *) "button", (char *) "None", CFGF_NONE
),
521 CFG_STR((char *) "command", (char *) "", CFGF_NONE
),
522 CFG_STR((char *) "arg", NULL
, CFGF_NONE
),
525 static cfg_opt_t widget_opts
[] =
527 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
528 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
529 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
532 static cfg_opt_t widget_taglist_opts
[] =
534 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
535 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
536 CFG_SEC((char *) "mouse", mouse_taglist_opts
, CFGF_MULTI
),
539 static cfg_opt_t widget_iconbox_opts
[] =
541 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
542 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
543 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
544 CFG_STR((char *) "image", (char *) NULL
, CFGF_NONE
),
545 CFG_BOOL((char *) "resize", cfg_true
, CFGF_NONE
),
548 static cfg_opt_t widget_textbox_opts
[] =
550 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
551 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
552 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
553 CFG_INT((char *) "width", 0, CFGF_NONE
),
554 CFG_STR((char *) "text", (char *) NULL
, CFGF_NONE
),
555 CFG_STR((char *) "fg", (char *) NULL
, CFGF_NONE
),
556 CFG_STR((char *) "bg", (char *) NULL
, CFGF_NONE
),
557 CFG_STR((char *) "font", (char *) NULL
, CFGF_NONE
),
558 CFG_STR((char *) "align", (char *) "center", CFGF_NONE
),
561 static cfg_opt_t widget_focustitle_opts
[] =
563 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
564 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
565 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
566 CFG_STR((char *) "fg", (char *) NULL
, CFGF_NONE
),
567 CFG_STR((char *) "bg", (char *) NULL
, CFGF_NONE
),
568 CFG_STR((char *) "font", (char *) NULL
, CFGF_NONE
),
569 CFG_STR((char *) "align", (char *) "left", CFGF_NONE
),
572 static cfg_opt_t widget_tasklist_opts
[] =
574 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
575 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
576 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
577 CFG_STR((char *) "fg", (char *) NULL
, CFGF_NONE
),
578 CFG_STR((char *) "bg", (char *) NULL
, CFGF_NONE
),
579 CFG_STR((char *) "focus_fg", (char *) NULL
, CFGF_NONE
),
580 CFG_STR((char *) "focus_bg", (char *) NULL
, CFGF_NONE
),
581 CFG_STR((char *) "font", (char *) NULL
, CFGF_NONE
),
582 CFG_STR((char *) "align", (char *) "left", CFGF_NONE
),
583 CFG_BOOL((char *) "show_icons", cfg_true
, CFGF_NONE
),
584 CFG_BOOL((char *) "show_all", cfg_false
, CFGF_NONE
),
587 static cfg_opt_t widget_graph_opts
[] =
589 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
590 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
591 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
592 CFG_INT((char *) "width", 100, CFGF_NONE
),
593 CFG_INT((char *) "padding_left", 0, CFGF_NONE
),
594 CFG_FLOAT((char *) "height", 0.67, CFGF_NONE
),
595 CFG_STR((char *) "fg", (char *) NULL
, CFGF_NONE
),
596 CFG_STR((char *) "bg", (char *) NULL
, CFGF_NONE
),
597 CFG_STR((char *) "bordercolor", (char *) NULL
, CFGF_NONE
),
598 CFG_BOOL((char *) "scale", cfg_false
, CFGF_NONE
),
599 CFG_FLOAT((char *) "max", 100.0f
, CFGF_NONE
),
602 static cfg_opt_t widget_progressbar_bar_opts
[] =
604 CFG_STR((char *) "fg", (char *) NULL
, CFGF_NONE
),
605 CFG_STR((char *) "bg", (char *) NULL
, CFGF_NONE
),
606 CFG_STR((char *) "bordercolor", (char *) NULL
, CFGF_NONE
),
608 static cfg_opt_t widget_progressbar_opts
[] =
610 CFG_INT((char *) "x", 0xffffffff, CFGF_NONE
),
611 CFG_INT((char *) "y", 0xffffffff, CFGF_NONE
),
612 CFG_SEC((char *) "mouse", mouse_generic_opts
, CFGF_MULTI
),
613 CFG_SEC((char *) "bar", widget_progressbar_bar_opts
, CFGF_MULTI
),
614 CFG_INT((char *) "width", 100, CFGF_NONE
),
615 CFG_INT((char *) "gap", 2, CFGF_NONE
),
616 CFG_INT((char *) "padding_left", 0, CFGF_NONE
),
617 CFG_FLOAT((char *) "height", 0.67, CFGF_NONE
),
620 static cfg_opt_t statusbar_opts
[] =
622 CFG_STR((char *) "position", (char *) "top", CFGF_NONE
),
623 CFG_INT((char *) "height", 0, CFGF_NONE
),
624 CFG_INT((char *) "width", 0, CFGF_NONE
),
625 CFG_SEC((char *) "textbox", widget_textbox_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
626 CFG_SEC((char *) "taglist", widget_taglist_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
627 CFG_SEC((char *) "focustitle", widget_focustitle_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
628 CFG_SEC((char *) "layoutinfo", widget_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
629 CFG_SEC((char *) "iconbox", widget_iconbox_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
630 CFG_SEC((char *) "netwmicon", widget_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
631 CFG_SEC((char *) "progressbar", widget_progressbar_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
632 CFG_SEC((char *) "graph", widget_graph_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
633 CFG_SEC((char *) "tasklist", widget_tasklist_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
636 static cfg_opt_t tag_opts
[] =
638 CFG_STR((char *) "layout", (char *) "tile", CFGF_NONE
),
639 CFG_FLOAT((char *) "mwfact", 0.5, CFGF_NONE
),
640 CFG_INT((char *) "nmaster", 1, CFGF_NONE
),
641 CFG_INT((char *) "ncol", 1, CFGF_NONE
),
644 static cfg_opt_t tags_opts
[] =
646 CFG_SEC((char *) "tag", tag_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
649 static cfg_opt_t layout_opts
[] =
651 CFG_STR((char *) "image", NULL
, CFGF_NONE
),
654 static cfg_opt_t layouts_opts
[] =
656 CFG_SEC((char *) "layout", layout_opts
, CFGF_TITLE
| CFGF_MULTI
),
659 static cfg_opt_t padding_opts
[] =
661 CFG_INT((char *) "top", 0, CFGF_NONE
),
662 CFG_INT((char *) "bottom", 0, CFGF_NONE
),
663 CFG_INT((char *) "right", 0, CFGF_NONE
),
664 CFG_INT((char *) "left", 0, CFGF_NONE
),
667 static cfg_opt_t screen_opts
[] =
669 CFG_SEC((char *) "general", general_opts
, CFGF_NONE
),
670 CFG_SEC((char *) "statusbar", statusbar_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
671 CFG_SEC((char *) "tags", tags_opts
, CFGF_NONE
),
672 CFG_SEC((char *) "colors", colors_opts
, CFGF_NONE
),
673 CFG_SEC((char *) "layouts", layouts_opts
, CFGF_NONE
),
674 CFG_SEC((char *) "padding", padding_opts
, CFGF_NONE
),
677 static cfg_opt_t rule_opts
[] =
679 CFG_STR((char *) "xproperty_name", NULL
, CFGF_NONE
),
680 CFG_STR((char *) "xproperty_value", NULL
, CFGF_NONE
),
681 CFG_STR((char *) "name", NULL
, CFGF_NONE
),
682 CFG_STR((char *) "tags", NULL
, CFGF_NONE
),
683 CFG_STR((char *) "icon", NULL
, CFGF_NONE
),
684 CFG_STR((char *) "float", (char *) "auto", CFGF_NONE
),
685 CFG_INT((char *) "screen", RULE_NOSCREEN
, CFGF_NONE
),
686 CFG_BOOL((char *) "not_master", cfg_false
, CFGF_NONE
),
689 static cfg_opt_t rules_opts
[] =
691 CFG_SEC((char *) "rule", rule_opts
, CFGF_MULTI
),
694 static cfg_opt_t key_opts
[] =
696 CFG_STR_LIST((char *) "modkey", (char *) "{Mod4}", CFGF_NONE
),
697 CFG_STR((char *) "key", (char *) "None", CFGF_NONE
),
698 CFG_STR((char *) "command", (char *) "", CFGF_NONE
),
699 CFG_STR((char *) "arg", NULL
, CFGF_NONE
),
702 static cfg_opt_t keylist_opts
[] =
704 CFG_STR_LIST((char *) "modkey", (char *) "{Mod4}", CFGF_NONE
),
705 CFG_STR_LIST((char *) "keylist", (char *) NULL
, CFGF_NONE
),
706 CFG_STR((char *) "command", (char *) "", CFGF_NONE
),
707 CFG_STR_LIST((char *) "arglist", NULL
, CFGF_NONE
),
710 static cfg_opt_t keys_opts
[] =
712 CFG_SEC((char *) "key", key_opts
, CFGF_MULTI
),
713 CFG_SEC((char *) "keylist", keylist_opts
, CFGF_MULTI
),
716 static cfg_opt_t mouse_opts
[] =
718 CFG_SEC((char *) "root", mouse_generic_opts
, CFGF_MULTI
),
719 CFG_SEC((char *) "client", mouse_generic_opts
, CFGF_MULTI
),
722 static cfg_opt_t opts
[] =
724 CFG_SEC((char *) "screen", screen_opts
, CFGF_TITLE
| CFGF_MULTI
| CFGF_NO_TITLE_DUPES
),
725 CFG_SEC((char *) "rules", rules_opts
, CFGF_NONE
),
726 CFG_SEC((char *) "keys", keys_opts
, CFGF_NONE
),
727 CFG_SEC((char *) "mouse", mouse_opts
, CFGF_NONE
),
730 cfg_t
*cfg
, *cfg_rules
, *cfg_keys
, *cfg_mouse
, *cfgsectmp
;
735 ssize_t confpath_len
;
737 FILE *defconfig
= NULL
;
740 confpath
= a_strdup(confpatharg
);
743 homedir
= getenv("HOME");
744 confpath_len
= a_strlen(homedir
) + a_strlen(AWESOME_CONFIG_FILE
) + 2;
745 confpath
= p_new(char, confpath_len
);
746 a_strcpy(confpath
, confpath_len
, homedir
);
747 a_strcat(confpath
, confpath_len
, "/");
748 a_strcat(confpath
, confpath_len
, AWESOME_CONFIG_FILE
);
751 globalconf
.configpath
= a_strdup(confpath
);
753 cfg
= cfg_init(opts
, CFGF_NONE
);
755 ret
= cfg_parse(cfg
, confpath
);
756 if(ret
== CFG_FILE_ERROR
)
758 perror("awesome: parsing configuration file failed");
759 if(!(defconfig
= fopen(confpath
, "w")))
760 perror("awesome: unable to create default configuration file");
762 else if(ret
== CFG_PARSE_ERROR
)
763 cfg_error(cfg
, "awesome: parsing configuration file %s failed.\n", confpath
);
764 if(ret
!= CFG_SUCCESS
) {
765 fprintf(stderr
, "Using default compile-time configuration\n");
767 cfg
= cfg_init(opts
, CFGF_NONE
);
768 cfg_parse_buf(cfg
, AWESOME_DEFAULT_CONFIG
);
771 /* get the right screen section */
772 for(screen
= 0; screen
< get_screen_count(); screen
++)
773 config_parse_screen(cfg
, screen
);
775 /* get general sections */
776 cfg_rules
= cfg_getsec(cfg
, "rules");
777 cfg_keys
= cfg_getsec(cfg
, "keys");
778 cfg_mouse
= cfg_getsec(cfg
, "mouse");
781 if(cfg_size(cfg_rules
, "rule"))
783 globalconf
.rules
= rule
= p_new(Rule
, 1);
784 for(i
= 0; i
< cfg_size(cfg_rules
, "rule"); i
++)
786 cfgsectmp
= cfg_getnsec(cfg_rules
, "rule", i
);
787 rule
->prop_r
= rules_compile_regex(cfg_getstr(cfgsectmp
, "name"));
788 rule
->tags_r
= rules_compile_regex(cfg_getstr(cfgsectmp
, "tags"));
789 rule
->xprop
= a_strdup(cfg_getstr(cfgsectmp
, "xproperty_name"));
790 rule
->xpropval_r
= rules_compile_regex(cfg_getstr(cfgsectmp
, "xproperty_value"));
791 rule
->icon
= a_strdup(cfg_getstr(cfgsectmp
, "icon"));
792 rule
->isfloating
= rules_get_float_from_str(cfg_getstr(cfgsectmp
, "float"));
793 rule
->screen
= cfg_getint(cfgsectmp
, "screen");
794 rule
->not_master
= cfg_getbool(cfgsectmp
, "not_master");
795 if(rule
->screen
>= get_screen_count())
798 if(i
< cfg_size(cfg_rules
, "rule") - 1)
799 rule
= rule
->next
= p_new(Rule
, 1);
805 globalconf
.rules
= NULL
;
807 /* Mouse: root window click bindings */
808 globalconf
.buttons
.root
= parse_mouse_bindings(cfg_mouse
, "root", True
);
810 /* Mouse: client windows click bindings */
811 globalconf
.buttons
.client
= parse_mouse_bindings(cfg_mouse
, "client", True
);
814 globalconf
.numlockmask
= get_numlockmask(globalconf
.display
);
816 globalconf
.keys
= section_keys(cfg_keys
);
820 cfg_print(cfg
, defconfig
);
824 /* Free! Like a river! */
829 // vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80