mirror of
https://github.com/mintycube/dwm.git
synced 2024-10-22 12:05:45 +00:00
91 lines
2.1 KiB
C
91 lines
2.1 KiB
C
int
|
|
width_awesomebar(Bar *bar, BarArg *a)
|
|
{
|
|
return a->w;
|
|
}
|
|
|
|
int
|
|
draw_awesomebar(Bar *bar, BarArg *a)
|
|
{
|
|
int n = 0, scm, remainder = 0, tabw, pad;
|
|
unsigned int i;
|
|
#if BAR_TITLE_LEFT_PAD_PATCH && BAR_TITLE_RIGHT_PAD_PATCH
|
|
int x = a->x + lrpad / 2, w = a->w - lrpad;
|
|
#elif BAR_TITLE_LEFT_PAD_PATCH
|
|
int x = a->x + lrpad / 2, w = a->w - lrpad / 2;
|
|
#elif BAR_TITLE_RIGHT_PAD_PATCH
|
|
int x = a->x, w = a->w - lrpad / 2;
|
|
#else
|
|
int x = a->x, w = a->w;
|
|
#endif // BAR_TITLE_LEFT_PAD_PATCH | BAR_TITLE_RIGHT_PAD_PATCH
|
|
|
|
Client *c;
|
|
for (c = bar->mon->clients; c; c = c->next)
|
|
if (ISVISIBLE(c))
|
|
n++;
|
|
|
|
if (n > 0) {
|
|
remainder = w % n;
|
|
tabw = w / n;
|
|
for (i = 0, c = bar->mon->clients; c; c = c->next, i++) {
|
|
if (!ISVISIBLE(c))
|
|
continue;
|
|
if (bar->mon->sel == c && HIDDEN(c))
|
|
scm = SchemeHidSel;
|
|
else if (HIDDEN(c))
|
|
scm = SchemeHidNorm;
|
|
else if (bar->mon->sel == c)
|
|
scm = SchemeTitleSel;
|
|
else
|
|
scm = SchemeTitleNorm;
|
|
|
|
pad = lrpad / 2;
|
|
#if BAR_CENTEREDWINDOWNAME_PATCH
|
|
if (TEXTW(c->name) < tabw)
|
|
pad = (tabw - TEXTW(c->name) + lrpad) / 2;
|
|
#endif // BAR_CENTEREDWINDOWNAME_PATCH
|
|
|
|
drw_setscheme(drw, scheme[scm]);
|
|
|
|
#if BAR_WINICON_PATCH
|
|
drw_text(drw, x, a->y, tabw + (i < remainder ? 1 : 0), 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, tabw + (i < remainder ? 1 : 0), a->h, pad, c->name, 0, False);
|
|
#endif // BAR_WINICON_PATCH
|
|
|
|
drawstateindicator(c->mon, c, 1, x, a->y, tabw + (i < remainder ? 1 : 0), a->h, 0, 0, c->isfixed);
|
|
x += tabw + (i < remainder ? 1 : 0);
|
|
}
|
|
}
|
|
return n;
|
|
}
|
|
|
|
int
|
|
click_awesomebar(Bar *bar, Arg *arg, BarArg *a)
|
|
{
|
|
int x = 0, n = 0;
|
|
Client *c;
|
|
|
|
for (c = bar->mon->clients; c; c = c->next)
|
|
if (ISVISIBLE(c))
|
|
n++;
|
|
|
|
c = bar->mon->clients;
|
|
|
|
do {
|
|
if (!c || !ISVISIBLE(c))
|
|
continue;
|
|
else
|
|
x += (1.0 / (double)n) * a->w;
|
|
} while (c && a->x > x && (c = c->next));
|
|
|
|
if (c) {
|
|
arg->v = c;
|
|
return ClkWinTitle;
|
|
}
|
|
return -1;
|
|
}
|
|
|