summaryrefslogtreecommitdiff
path: root/app/cwm/parse.y
diff options
context:
space:
mode:
authorOkan Demirmen <okan@cvs.openbsd.org>2009-05-17 23:40:58 +0000
committerOkan Demirmen <okan@cvs.openbsd.org>2009-05-17 23:40:58 +0000
commit49c64852885aadb1bd54f8e5d2a1961363db7461 (patch)
tree8c29c10285b08cdd10854a7a7c94ec5e359519f1 /app/cwm/parse.y
parent643784d1e14fb8db12be54b8c9f89cc3bbc725f3 (diff)
a long time coming - re-work the way we deal with colors: since we're
using Xft(3), use it to select the font color as well instead of trying to build one; properly allocate and free colors at-will, e.g. we now have configurable colors. feedback and ok's todd@ and oga@
Diffstat (limited to 'app/cwm/parse.y')
-rw-r--r--app/cwm/parse.y36
1 files changed, 35 insertions, 1 deletions
diff --git a/app/cwm/parse.y b/app/cwm/parse.y
index 53a2a6d8e..72489fa4a 100644
--- a/app/cwm/parse.y
+++ b/app/cwm/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.19 2009/02/07 21:07:00 martynas Exp $ */
+/* $OpenBSD: parse.y,v 1.20 2009/05/17 23:40:57 okan Exp $ */
/*
* Copyright (c) 2002, 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -67,6 +67,9 @@ typedef struct {
%token FONTNAME STICKY GAP MOUSEBIND
%token AUTOGROUP BIND COMMAND IGNORE
%token YES NO BORDERWIDTH MOVEAMOUNT
+%token COLOR
+%token ACTIVEBORDER INACTIVEBORDER
+%token GROUPBORDER UNGROUPBORDER
%token ERROR
%token <v.string> STRING
%token <v.number> NUMBER
@@ -77,6 +80,7 @@ typedef struct {
grammar : /* empty */
| grammar '\n'
| grammar main '\n'
+ | grammar color '\n'
| grammar error '\n' { file->errors++; }
;
@@ -170,6 +174,27 @@ main : FONTNAME STRING {
free($3);
}
;
+
+color : COLOR colors
+ ;
+
+colors : ACTIVEBORDER STRING {
+ free(conf->color[CWM_COLOR_BORDOR_ACTIVE].name);
+ conf->color[CWM_COLOR_BORDOR_ACTIVE].name = $2;
+ }
+ | INACTIVEBORDER STRING {
+ free(conf->color[CWM_COLOR_BORDER_INACTIVE].name);
+ conf->color[CWM_COLOR_BORDER_INACTIVE].name = $2;
+ }
+ | GROUPBORDER STRING {
+ free(conf->color[CWM_COLOR_BORDER_GROUP].name);
+ conf->color[CWM_COLOR_BORDER_GROUP].name = $2;
+ }
+ | UNGROUPBORDER STRING {
+ free(conf->color[CWM_COLOR_BORDER_UNGROUP].name);
+ conf->color[CWM_COLOR_BORDER_UNGROUP].name = $2;
+ }
+ ;
%%
struct keywords {
@@ -202,17 +227,22 @@ lookup(char *s)
{
/* this has to be sorted always */
static const struct keywords keywords[] = {
+ { "activeborder", ACTIVEBORDER},
{ "autogroup", AUTOGROUP},
{ "bind", BIND},
{ "borderwidth", BORDERWIDTH},
+ { "color", COLOR},
{ "command", COMMAND},
{ "fontname", FONTNAME},
{ "gap", GAP},
+ { "groupborder", GROUPBORDER},
{ "ignore", IGNORE},
+ { "inactiveborder", INACTIVEBORDER},
{ "mousebind", MOUSEBIND},
{ "moveamount", MOVEAMOUNT},
{ "no", NO},
{ "sticky", STICKY},
+ { "ungroupborder", UNGROUPBORDER},
{ "yes", YES}
};
const struct keywords *p;
@@ -498,6 +528,7 @@ parse_config(const char *filename, struct conf *xconf)
struct winmatch *wm;
struct cmd *cmd;
struct mousebinding *mb;
+ int i;
conf_clear(xconf);
@@ -535,6 +566,9 @@ parse_config(const char *filename, struct conf *xconf)
strlcpy(xconf->lockpath, conf->lockpath,
sizeof(xconf->lockpath));
+ for (i = 0; i < CWM_COLOR_MAX; i++)
+ xconf->color[i].name = conf->color[i].name;
+
xconf->DefaultFontName = conf->DefaultFontName;
bcopy(&(conf->gap_top), &(xconf->gap_top), sizeof(int) * 4);