X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=tag.c;h=5da3c31811a809ea4e5a50254c48a6fea46c2e49;hb=2b5553b1ebf7c8e59b5ecf7128b932115ff2b313;hp=85098671303bcbcf6cab64b2fae5e7877e44fb17;hpb=11737233a7ce6bc656bc7bc061c68eeda824ee9b;p=dwm.git diff --git a/tag.c b/tag.c index 8509867..5da3c31 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,8 +53,8 @@ dofloat(Arg *arg) { Client *c; - arrange = dofloat; for(c = clients; c; c = c->next) { + c->ismax = False; if(c->tags[tsel]) { resize(c, True, TopLeft); } @@ -71,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++; @@ -86,6 +87,7 @@ dotile(Arg *arg) h = sh - bh; for(i = 0, c = clients; c; c = c->next) { + c->ismax = False; if(c->tags[tsel]) { if(c->isfloat) { higher(c); @@ -161,6 +163,7 @@ void replacetag(Arg *arg) { int i; + if(!sel) return; @@ -212,6 +215,13 @@ settags(Client *c) } void +togglemode(Arg *arg) +{ + arrange = arrange == dofloat ? dotile : dofloat; + arrange(NULL); +} + +void view(Arg *arg) { tsel = arg->i;