Added hide vacant tags patch
This commit is contained in:
parent
b1270a7208
commit
3ead516da8
3
config.h
3
config.h
|
|
@ -88,7 +88,8 @@ static Key keys[] = {
|
||||||
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
|
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
|
||||||
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
|
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
|
||||||
{ MODKEY, XK_e, spawn, SHCMD("setxkbmap us; kill -45 $(pidof dwmblocks)") },
|
{ MODKEY, XK_e, spawn, SHCMD("setxkbmap us; kill -45 $(pidof dwmblocks)") },
|
||||||
{ MODKEY, XK_s, spawn, SHCMD("setxkbmap es; kill -45 $(pidof dwmblocks)") },
|
{ MODKEY, XK_s, spawn, SHCMD("setxkbmap es; kill -45 $(pidof dwmblocks)") },
|
||||||
|
{ MODKEY|ShiftMask, XK_d, spawn, SHCMD("setxkbmap dvorak; kill -45 $(pidof dwmblocks)") },
|
||||||
{ MODKEY, XK_w, spawn, SHCMD("$BROWSER") },
|
{ MODKEY, XK_w, spawn, SHCMD("$BROWSER") },
|
||||||
{ MODKEY, XK_a, spawn, SHCMD("$flameshot gui") },
|
{ MODKEY, XK_a, spawn, SHCMD("$flameshot gui") },
|
||||||
{ MODKEY, XK_b, togglebar, {0} },
|
{ MODKEY, XK_b, togglebar, {0} },
|
||||||
|
|
|
||||||
17
dwm.c
17
dwm.c
|
|
@ -435,9 +435,15 @@ buttonpress(XEvent *e)
|
||||||
}
|
}
|
||||||
if (ev->window == selmon->barwin) {
|
if (ev->window == selmon->barwin) {
|
||||||
i = x = 0;
|
i = x = 0;
|
||||||
do
|
unsigned int occ = 0;
|
||||||
|
for(c = m->clients; c; c=c->next)
|
||||||
|
occ |= 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]);
|
x += TEXTW(tags[i]);
|
||||||
while (ev->x >= x && ++i < LENGTH(tags));
|
} while (ev->x >= x && ++i < LENGTH(tags));
|
||||||
if (i < LENGTH(tags)) {
|
if (i < LENGTH(tags)) {
|
||||||
click = ClkTagBar;
|
click = ClkTagBar;
|
||||||
arg.ui = 1 << i;
|
arg.ui = 1 << i;
|
||||||
|
|
@ -723,13 +729,12 @@ drawbar(Monitor *m)
|
||||||
}
|
}
|
||||||
x = 0;
|
x = 0;
|
||||||
for (i = 0; i < LENGTH(tags); i++) {
|
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]);
|
w = TEXTW(tags[i]);
|
||||||
drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]);
|
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);
|
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;
|
x += w;
|
||||||
}
|
}
|
||||||
w = blw = TEXTW(m->ltsymbol);
|
w = blw = TEXTW(m->ltsymbol);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user