X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=tag.c;h=d6c349b808e2a53134162e8a01bb3b062e2f819f;hb=4688ad181da14be36e034918580ec0ce5968ffdb;hp=82cf18aab65768022297fc70a81a4fdb7bee3582;hpb=bcaf6a7a0f492c3fafc4baabd2dc06f5191417ee;p=dwm.git diff --git a/tag.c b/tag.c index 82cf18a..d6c349b 100644 --- a/tag.c +++ b/tag.c @@ -20,9 +20,9 @@ typedef struct { /* CUSTOMIZE */ static Rule rule[] = { - /* class instance tags isfloat */ - { "Firefox.*", { [Twww] = "www" }, False }, - { "Gimp.*", { 0 }, True}, + /* class:instance tags isfloat */ + { "Firefox.*", { [Twww] = "www" }, False }, + { "Gimp.*", { 0 }, True}, }; /* extern */ @@ -51,9 +51,8 @@ dofloat(Arg *arg) { Client *c; - arrange = dofloat; for(c = clients; c; c = c->next) { - setgeom(c); + c->ismax = False; if(c->tags[tsel]) { resize(c, True, TopLeft); } @@ -72,11 +71,10 @@ dofloat(Arg *arg) void dotile(Arg *arg) { - Client *c; int n, i, w, h; + Client *c; w = sw - mw; - arrange = dotile; for(n = 0, c = clients; c; c = c->next) if(c->tags[tsel] && !c->isfloat) n++; @@ -87,7 +85,7 @@ dotile(Arg *arg) h = sh - bh; for(i = 0, c = clients; c; c = c->next) { - setgeom(c); + c->ismax = False; if(c->tags[tsel]) { if(c->isfloat) { higher(c); @@ -95,28 +93,28 @@ dotile(Arg *arg) continue; } if(n == 1) { - *c->x = sx; - *c->y = sy + bh; - *c->w = sw - 2 * c->border; - *c->h = sh - 2 * c->border - bh; + c->x = sx; + c->y = sy + bh; + c->w = sw - 2 * c->border; + c->h = sh - 2 * c->border - bh; } else if(i == 0) { - *c->x = sx; - *c->y = sy + bh; - *c->w = mw - 2 * c->border; - *c->h = sh - 2 * c->border - bh; + c->x = sx; + c->y = sy + bh; + c->w = mw - 2 * c->border; + c->h = sh - 2 * c->border - bh; } else if(h > bh) { - *c->x = sx + mw; - *c->y = sy + (i - 1) * h + bh; - *c->w = w - 2 * c->border; - *c->h = h - 2 * c->border; + c->x = sx + mw; + c->y = sy + (i - 1) * h + bh; + c->w = w - 2 * c->border; + c->h = h - 2 * c->border; } else { /* fallback if h < bh */ - *c->x = sx + mw; - *c->y = sy + bh; - *c->w = w - 2 * c->border; - *c->h = sh - 2 * c->border - bh; + c->x = sx + mw; + c->y = sy + bh; + c->w = w - 2 * c->border; + c->h = sh - 2 * c->border - bh; } resize(c, False, TopLeft); i++; @@ -163,6 +161,7 @@ void replacetag(Arg *arg) { int i; + if(!sel) return; @@ -213,6 +212,13 @@ settags(Client *c) c->tags[tsel] = tags[tsel]; } +void +togglemode(Arg *arg) +{ + arrange = arrange == dofloat ? dotile : dofloat; + arrange(NULL); +} + void view(Arg *arg) {