dwm
dynamic window manager
git clone https://9o.is/git/dwm.git
commit 4e2dd4017ea448f36b15a5d379e4c87d030c0f87 parent 47c3168baee7b4a80c02f3f459f01425f1ea6b18 Author: Jul <jul@9o.is> Date: Sun, 1 Feb 2026 10:03:07 -0500 move window title to lhs of status bar Diffstat:
| M | dwm.c | | | 61 | ++++++++++++++++++++++++++++++++++++++++--------------------- |
1 file changed, 40 insertions(+), 21 deletions(-)
diff --git a/dwm.c b/dwm.c @@ -437,19 +437,28 @@ buttonpress(XEvent *e) focus(NULL); } if (ev->window == selmon->barwin) { - i = x = 0; - do + x = TEXTW(stext) - lrpad + 2; + x += TEXTW(selmon->ltsymbol); + for (i = 0; i < LENGTH(tags); i++) x += TEXTW(tags[i]); - while (ev->x >= x && ++i < LENGTH(tags)); - if (i < LENGTH(tags)) { - click = ClkTagBar; - arg.ui = 1 << i; - } else if (ev->x < x + TEXTW(selmon->ltsymbol)) - click = ClkLtSymbol; - else if (ev->x > selmon->ww - (int)TEXTW(stext)) - click = ClkStatusText; - else + x = selmon->ww - x; + + if (ev->x < x) click = ClkWinTitle; + else { + i = 0; + do + x += TEXTW(tags[i]); + while (ev->x >= x && ++i < LENGTH(tags)); + if (i < LENGTH(tags)) { + click = ClkTagBar; + arg.ui = 1 << i; + } + else if (ev->x < x + TEXTW(selmon->ltsymbol)) + click = ClkLtSymbol; + else + click = ClkStatusText; + } } else if ((c = wintoclient(ev->window))) { focus(c); restack(selmon); @@ -721,12 +730,31 @@ drawbar(Monitor *m) drw_text(drw, m->ww - tw, 0, tw, bh, 0, stext, 0); } + tw += TEXTW(m->ltsymbol); + for (i = 0; i < LENGTH(tags); i++) { + tw += TEXTW(tags[i]); + } + for (c = m->clients; c; c = c->next) { occ |= c->tags; if (c->isurgent) urg |= c->tags; } + x = 0; + + if ((w = m->ww - tw - x) > bh) { + if (m->sel) { + drw_text(drw, x, 0, w, bh, lrpad / 2, m->sel->name, 0); + if (m->sel->isfloating) + drw_rect(drw, x + boxs, boxs, boxw, boxw, m->sel->isfixed, 0); + } else { + drw_setscheme(drw, scheme[SchemeNorm]); + drw_rect(drw, x, 0, w, bh, 1, 1); + } + x += w; + } + for (i = 0; i < LENGTH(tags); i++) { w = TEXTW(tags[i]); drw_setscheme(drw, scheme[m->tagset[m->seltags] & 1 << i ? SchemeSel : SchemeNorm]); @@ -737,20 +765,11 @@ drawbar(Monitor *m) urg & 1 << i); x += w; } + w = TEXTW(m->ltsymbol); drw_setscheme(drw, scheme[SchemeNorm]); x = drw_text(drw, x, 0, w, bh, lrpad / 2, m->ltsymbol, 0); - if ((w = m->ww - tw - x) > bh) { - if (m->sel) { - drw_text(drw, x, 0, w, bh, lrpad / 2, m->sel->name, 0); - if (m->sel->isfloating) - drw_rect(drw, x + boxs, boxs, boxw, boxw, m->sel->isfixed, 0); - } else { - drw_setscheme(drw, scheme[SchemeNorm]); - drw_rect(drw, x, 0, w, bh, 1, 1); - } - } drw_map(drw, m->barwin, 0, 0, m->ww, bh); }