X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=tag.c;h=21eb9fa280b760ab36239e839e9d8c03374f99ad;hb=72707c2fae68f5eba6ea97cbf356bfb968c8a15d;hp=82cf18aab65768022297fc70a81a4fdb7bee3582;hpb=bcaf6a7a0f492c3fafc4baabd2dc06f5191417ee;p=dwm.git diff --git a/tag.c b/tag.c index 82cf18a..21eb9fa 100644 --- a/tag.c +++ b/tag.c @@ -20,22 +20,24 @@ 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 */ - -/* CUSTOMIZE */ char *tags[TLast] = { [Tscratch] = "scratch", [Tdev] = "dev", [Twww] = "www", [Twork] = "work", }; + void (*arrange)(Arg *) = dotile; +/* END CUSTOMIZE */ + +/* extern */ + void appendtag(Arg *arg) { @@ -51,9 +53,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 +73,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 +87,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 +95,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++; @@ -140,6 +140,13 @@ getnext(Client *c, unsigned int t) return c; } +Client * +getprev(Client *c) +{ + for(; c && !c->tags[tsel]; c = c->prev); + return c; +} + void heretag(Arg *arg) { @@ -163,6 +170,7 @@ void replacetag(Arg *arg) { int i; + if(!sel) return; @@ -213,6 +221,13 @@ settags(Client *c) c->tags[tsel] = tags[tsel]; } +void +togglemode(Arg *arg) +{ + arrange = arrange == dofloat ? dotile : dofloat; + arrange(NULL); +} + void view(Arg *arg) {