summaryrefslogtreecommitdiff
path: root/tag.c
diff options
context:
space:
mode:
authorarg@10ksloc.org <unknown>2006-08-03 12:12:26 +0200
committerarg@10ksloc.org <unknown>2006-08-03 12:12:26 +0200
commitb35575574be53a1b3be42d7037d2f432a19a3890 (patch)
tree6be2344c68ec6590fa816bbd578e0f36fe21c0b8 /tag.c
parent666b4563a0064dd7aa27159813124837d306f81c (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.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/tag.c b/tag.c
index 90223717..b20e71e0 100644
--- a/tag.c
+++ b/tag.c
@@ -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(&regex, rule[i].pattern, 0)) {
if(!regexec(&regex, 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(&regex);
@@ -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);
}