diff options
author | arg@10ksloc.org | 2006-08-03 12:12:26 +0200 |
---|---|---|
committer | arg@10ksloc.org | 2006-08-03 12:12:26 +0200 |
commit | b35575574be53a1b3be42d7037d2f432a19a3890 (patch) | |
tree | 6be2344c68ec6590fa816bbd578e0f36fe21c0b8 /tag.c | |
parent | 666b4563a0064dd7aa27159813124837d306f81c (diff) |
removed TLast tag enum, now tags is simple defined as char *[] array, the rest is calculated correctly, rules take an int array for the tags
Diffstat (limited to 'tag.c')
-rw-r--r-- | tag.c | 19 |
1 files changed, 10 insertions, 9 deletions
@@ -13,7 +13,7 @@ typedef struct { const char *pattern; - Bool tags[TLast]; + const unsigned int *tags; Bool isfloat; } Rule; @@ -145,7 +145,7 @@ replacetag(Arg *arg) if(!sel) return; - for(i = 0; i < TLast; i++) + for(i = 0; i < ntags; i++) sel->tags[i] = False; appendtag(arg); } @@ -155,7 +155,7 @@ settags(Client *c) { char classinst[256]; static unsigned int len = sizeof(rule) / sizeof(rule[0]); - unsigned int i, j; + unsigned int i, j, n; regex_t regex; regmatch_t tmp; Bool matched = False; @@ -168,10 +168,11 @@ settags(Client *c) for(i = 0; !matched && i < len; i++) { if(!regcomp(®ex, rule[i].pattern, 0)) { if(!regexec(®ex, classinst, 1, &tmp, 0)) { - for(j = 0; j < TLast; j++) { - if((c->tags[j] = rule[i].tags[j])) - matched = True; - } + n = rule[i].tags ? + sizeof(rule[i].tags) / sizeof(rule[i].tags[0]) : 0; + matched = n != 0; + for(j = 0; j < n; j++) + c->tags[rule[i].tags[j]] = True; c->isfloat = rule[i].isfloat; } regfree(®ex); @@ -204,13 +205,13 @@ view(Arg *arg) void viewnext(Arg *arg) { - arg->i = (tsel < TLast-1) ? tsel+1 : 0; + arg->i = (tsel < ntags-1) ? tsel+1 : 0; view(arg); } void viewprev(Arg *arg) { - arg->i = (tsel > 0) ? tsel-1 : TLast-1; + arg->i = (tsel > 0) ? tsel-1 : ntags-1; view(arg); } |