summaryrefslogtreecommitdiffhomepage
path: root/patch/bar_wintitle.c
diff options
context:
space:
mode:
Diffstat (limited to 'patch/bar_wintitle.c')
-rw-r--r--patch/bar_wintitle.c45
1 files changed, 37 insertions, 8 deletions
diff --git a/patch/bar_wintitle.c b/patch/bar_wintitle.c
index d2241d2..72926f2 100644
--- a/patch/bar_wintitle.c
+++ b/patch/bar_wintitle.c
@@ -18,7 +18,6 @@ draw_wintitle(Bar *bar, BarArg *a)
#endif // BAR_TITLE_LEFT_PAD_PATCH | BAR_TITLE_RIGHT_PAD_PATCH
Monitor *m = bar->mon;
Client *c = m->sel;
- int pad = lrpad / 2;
if (!c) {
drw_setscheme(drw, scheme[SchemeTitleNorm]);
@@ -26,23 +25,53 @@ draw_wintitle(Bar *bar, BarArg *a)
return 0;
}
+ int tpad = lrpad / 2;
+ #if BAR_WINICON_PATCH
+ int ipad = c->icon ? c->icon->width + ICONSPACING : 0;
+ #endif // BAR_WINICON_PATCH
+ #if BAR_CENTEREDWINDOWNAME_PATCH
+ int cpad = 0;
+ #endif // BAR_CENTEREDWINDOWNAME_PATCH
+ int tx = x;
+ int tw = w;
+
drw_setscheme(drw, scheme[m == selmon ? SchemeTitleSel : SchemeTitleNorm]);
#if BAR_IGNORE_XFT_ERRORS_WHEN_DRAWING_TEXT_PATCH
XSetErrorHandler(xerrordummy);
#endif // BAR_IGNORE_XFT_ERRORS_WHEN_DRAWING_TEXT_PATCH
+
+ if (w <= TEXTW("A") - lrpad + tpad) // reduce text padding if wintitle is too small
+ tpad = (w - TEXTW("A") + lrpad < 0 ? 0 : (w - TEXTW("A") + lrpad) / 2);
+ #if BAR_WINICON_PATCH && BAR_CENTEREDWINDOWNAME_PATCH
+ else if (TEXTW(c->name) + ipad < w)
+ cpad = (w - TEXTW(c->name) - ipad) / 2;
+ #elif BAR_CENTEREDWINDOWNAME_PATCH
+ else if (TEXTW(c->name) < w)
+ cpad = (w - TEXTW(c->name)) / 2;
+ #endif // BAR_CENTEREDWINDOWNAME_PATCH
+
+ XSetForeground(drw->dpy, drw->gc, drw->scheme[ColBg].pixel);
+ XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, a->y, w, a->h);
+
#if BAR_CENTEREDWINDOWNAME_PATCH
- if (TEXTW(c->name) < w)
- pad = (w - TEXTW(c->name) + lrpad) / 2;
+ /* Apply center padding, if any */
+ tx += cpad;
+ tw -= cpad;
#endif // BAR_CENTEREDWINDOWNAME_PATCH
+ tx += tpad;
+ tw -= lrpad;
+
#if BAR_WINICON_PATCH
- drw_text(drw, x, a->y, w, a->h, pad + (c->icon ? c->icon->width + ICONSPACING : 0), c->name, 0, False);
- if (c->icon)
- drw_img(drw, x + pad, a->y + (a->h - c->icon->height) / 2, c->icon, tmpicon);
- #else
- drw_text(drw, x, a->y, w, a->h, pad, c->name, 0, False);
+ if (ipad) {
+ drw_img(drw, tx, a->y + (a->h - c->icon->height) / 2, c->icon, tmpicon);
+ tx += ipad;
+ tw -= ipad;
+ }
#endif // BAR_WINICON_PATCH
+ drw_text(drw, tx, a->y, tw, a->h, 0, c->name, 0, False);
+
#if BAR_IGNORE_XFT_ERRORS_WHEN_DRAWING_TEXT_PATCH
XSync(dpy, False);
XSetErrorHandler(xerror);