aboutsummaryrefslogtreecommitdiffstats
path: root/applied/dwm-fancybar-20220527-d3f93c7.diff
diff options
context:
space:
mode:
authorJoe <rbo@gmx.us>2024-12-24 14:38:57 +0100
committerJoe <rbo@gmx.us>2024-12-24 14:38:57 +0100
commit0b402ddabf4236bddb580f39733004440a7ede63 (patch)
tree1183dac1839b031ad9ef7618763d9fc94911f7bc /applied/dwm-fancybar-20220527-d3f93c7.diff
parentstatus2d (diff)
downloaddwm-0b402ddabf4236bddb580f39733004440a7ede63.tar.gz
dwm-0b402ddabf4236bddb580f39733004440a7ede63.tar.bz2
dwm-0b402ddabf4236bddb580f39733004440a7ede63.tar.xz
dwm-0b402ddabf4236bddb580f39733004440a7ede63.tar.zst
dwm-0b402ddabf4236bddb580f39733004440a7ede63.zip
up
Diffstat (limited to 'applied/dwm-fancybar-20220527-d3f93c7.diff')
-rw-r--r--applied/dwm-fancybar-20220527-d3f93c7.diff73
1 files changed, 0 insertions, 73 deletions
diff --git a/applied/dwm-fancybar-20220527-d3f93c7.diff b/applied/dwm-fancybar-20220527-d3f93c7.diff
deleted file mode 100644
index e2a4e2a..0000000
--- a/applied/dwm-fancybar-20220527-d3f93c7.diff
+++ /dev/null
@@ -1,73 +0,0 @@
-diff --git a/dwm.c b/dwm.c
---- a/dwm.c
-+++ b/dwm.c
-@@ -699,10 +699,10 @@ dirtomon(int dir)
- void
- drawbar(Monitor *m)
- {
-- int x, w, tw = 0;
-+ int x, w, tw = 0, mw, ew = 0;
- int boxs = drw->fonts->h / 9;
- int boxw = drw->fonts->h / 6 + 2;
-- unsigned int i, occ = 0, urg = 0;
-+ unsigned int i, occ = 0, urg = 0, n = 0;
- Client *c;
-
- if (!m->showbar)
-@@ -716,6 +716,8 @@ drawbar(Monitor *m)
- }
-
- for (c = m->clients; c; c = c->next) {
-+ if (ISVISIBLE(c))
-+ n++;
- occ |= c->tags;
- if (c->isurgent)
- urg |= c->tags;
-@@ -736,15 +738,39 @@ drawbar(Monitor *m)
- 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);
-+ if (n > 0) {
-+ tw = TEXTW(m->sel->name) + lrpad;
-+ mw = (tw >= w || n == 1) ? 0 : (w - tw) / (n - 1);
-+
-+ i = 0;
-+ for (c = m->clients; c; c = c->next) {
-+ if (!ISVISIBLE(c) || c == m->sel)
-+ continue;
-+ tw = TEXTW(c->name);
-+ if(tw < mw)
-+ ew += (mw - tw);
-+ else
-+ i++;
-+ }
-+ if (i > 0)
-+ mw += ew / i;
-+
-+ for (c = m->clients; c; c = c->next) {
-+ if (!ISVISIBLE(c))
-+ continue;
-+ tw = MIN(m->sel == c ? w : mw, TEXTW(c->name));
-+
-+ drw_setscheme(drw, scheme[m == selmon && m->sel == c ? SchemeSel : SchemeNorm]);
-+ if (tw > lrpad / 2)
-+ drw_text(drw, x, 0, tw, bh, lrpad / 2, c->name, 0);
-+ if (c->isfloating)
-+ drw_rect(drw, x + boxs, boxs, boxw, boxw, c->isfixed, 0);
-+ x += tw;
-+ w -= tw;
-+ }
- }
-+ drw_setscheme(drw, scheme[SchemeNorm]);
-+ drw_rect(drw, x, 0, w, bh, 1, 1);
- }
- drw_map(drw, m->barwin, 0, 0, m->ww, bh);
- }