diff options
author | Anselm R Garbe <anselm@garbe.us> | 2009-07-09 19:58:58 +0100 |
---|---|---|
committer | Anselm R Garbe <anselm@garbe.us> | 2009-07-09 19:58:58 +0100 |
commit | 87526be6f05ed892083d874c27f18b6c9e21881e (patch) | |
tree | 07a05c6309aa0c3416ef385725b5a8ff9e0a37e3 /dwm.c | |
parent | 565050ac51687bbd4f388c6aeb2298db94430efb (diff) | |
download | dwm-87526be6f05ed892083d874c27f18b6c9e21881e.tar.gz |
added client number printing right of layout symbol
Diffstat (limited to 'dwm.c')
-rw-r--r-- | dwm.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/dwm.c b/dwm.c index 07d0d36..d71bb58 100644 --- a/dwm.c +++ b/dwm.c @@ -236,7 +236,7 @@ static int xerrorstart(Display *dpy, XErrorEvent *ee); static void zoom(const Arg *arg); /* variables */ -static char stext[256]; +static char stext[256], ntext[8]; static int screen; static int sw, sh; /* X display screen geometry x, y, width, height */ static int bh, blw = 0; /* bar geometry */ @@ -641,11 +641,13 @@ dirtomon(int dir) { void drawbar(Monitor *m) { int x; - unsigned int i, occ = 0, urg = 0; + unsigned int i, n = 0, occ = 0, urg = 0; unsigned long *col; Client *c; for(c = m->clients; c; c = c->next) { + if(ISVISIBLE(c)) + n++; occ |= c->tags; if(c->isurgent) urg |= c->tags; @@ -662,10 +664,12 @@ drawbar(Monitor *m) { if(blw > 0) { dc.w = blw; drawtext(m->lt[m->sellt]->symbol, dc.norm, False); - x = dc.x + dc.w; + dc.x += dc.w; } - else - x = dc.x; + snprintf(ntext, sizeof ntext, "%u", n); + dc.w = TEXTW(ntext); + drawtext(ntext, dc.norm, False); + x = (dc.x += dc.w); if(m == selmon) { /* status is only drawn on selected monitor */ dc.w = TEXTW(stext); dc.x = m->ww - dc.w; |