diff options
author | Malfurious <m@lfurio.us> | 2020-06-21 23:54:02 -0400 |
---|---|---|
committer | Malfurious <m@lfurio.us> | 2023-06-03 21:49:57 -0400 |
commit | 90ad973c18f2ad10f06bd2b361b6367383d1f1c6 (patch) | |
tree | 17536c2bc08ae7b7694842e139ceb0ba95a09f25 | |
parent | a582da75a740dc007f25542b0da41c7a76a829ab (diff) | |
download | dwm-90ad973c18f2ad10f06bd2b361b6367383d1f1c6.tar.gz dwm-90ad973c18f2ad10f06bd2b361b6367383d1f1c6.zip |
patch: hide vacant tags
This patch prevents dwm from drawing tags with no clients (i.e. vacant)
on the bar.
It also makes sure that pressing a tag on the bar behaves accordingly by
not reserving reactive regions on the bar for vacant tags.
It also stops drawing empty rectangles on the bar for non-vacant tags as
there is no need anymore to distinguish vacant tags and it offers a more
visible contrast than if there were filled/empty rectangles.
-rw-r--r-- | dwm.c | 21 |
1 files changed, 13 insertions, 8 deletions
@@ -440,7 +440,7 @@ attachstack(Client *c) void buttonpress(XEvent *e) { - unsigned int i, x, click; + unsigned int i, x, click, occ = 0; Arg arg = {0}; Client *c; Monitor *m; @@ -455,9 +455,14 @@ buttonpress(XEvent *e) } if (ev->window == selmon->barwin) { i = x = 0; - do + for (c = m->clients; c; c = c->next) + occ |= c->tags == 255 ? 0 : c->tags; + do { + /* do not reserve space for vacant tags */ + if (!(occ & 1 << i || m->tagset[m->seltags] & 1 << i)) + continue; x += TEXTW(tags[i]); - while (ev->x >= x && ++i < LENGTH(tags)); + } while (ev->x >= x && ++i < LENGTH(tags)); if (i < LENGTH(tags)) { click = ClkTagBar; arg.ui = 1 << i; @@ -733,19 +738,19 @@ drawbar(Monitor *m) } for (c = m->clients; c; c = c->next) { - occ |= c->tags; + occ |= c->tags == 255 ? 0 : c->tags; if (c->isurgent) urg |= c->tags; } x = 0; for (i = 0; i < LENGTH(tags); i++) { + /* do not draw vacant tags */ + if (!(occ & 1 << i || m->tagset[m->seltags] & 1 << i)) + continue; + w = TEXTW(tags[i]); drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]); drw_text(drw, x, 0, w, bh, lrpad / 2, tags[i], urg & 1 << i); - if (occ & 1 << i) - drw_rect(drw, x + boxs, boxs, boxw, boxw, - m == selmon && selmon->sel && selmon->sel->tags & 1 << i, - urg & 1 << i); x += w; } w = TEXTW(m->ltsymbol); |