diff options
| author | Naz <ndpm13@ch-naseem.com> | 2026-01-20 11:47:48 +0100 |
|---|---|---|
| committer | Naz <ndpm13@ch-naseem.com> | 2026-01-20 11:47:48 +0100 |
| commit | 4dd29beb7d309baf2af3fe1bba65cd73db44777e (patch) | |
| tree | e23a6f06a25cb04b46a44d639b3ba5acfa5c4b69 /dwm.c | |
| parent | dfbbd35b0919ed7e9aeec3b3f7bf0338d4438f9c (diff) | |
feat(patch): dwm-splitstatus-20201114-61bb8b2
Diffstat (limited to 'dwm.c')
| -rw-r--r-- | dwm.c | 30 |
1 files changed, 15 insertions, 15 deletions
@@ -795,12 +795,9 @@ drawbar(Monitor *m) if (!m->showbar) return; - /* draw status first so it can be overdrawn by tags later */ - if (m == selmon) { /* status is only drawn on selected monitor */ - drw_setscheme(drw, scheme[SchemeNorm]); - tw = TEXTW(stext) - lrpad + 2; /* 2px right padding */ - drw_text(drw, m->ww - tw, 0, tw, bh, 0, stext, 0); - } + char *mstext; + char *rstext; + int msx; for (c = m->clients; c; c = c->next) { occ |= c->tags; @@ -822,17 +819,20 @@ drawbar(Monitor *m) 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_setscheme(drw, scheme[m == selmon ? SchemeSel : SchemeNorm]); - 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_setscheme(drw, scheme[SchemeNorm]); + drw_rect(drw, x, 0, m->ww - x, bh, 1, 1); + + if (m == selmon) { /* status is only drawn on selected monitor */ + rstext = strdup(stext); + if (splitstatus) { + mstext = strsep(&rstext, splitdelim); + msx = (m->ww - TEXTW(mstext) + lrpad) / 2; /* x position of middle status text */ + drw_text(drw, msx, 0, TEXTW(mstext) - lrpad, bh, 0, mstext, 0); } + tw = TEXTW(rstext) - lrpad + 2; /* 2px right padding */ + drw_text(drw, m->ww - tw, 0, tw, bh, 0, rstext, 0); } + drw_map(drw, m->barwin, 0, 0, m->ww, bh); } |
