about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorAnselm R Garbe <anselm@garbe.us>2009-07-09 19:58:58 +0100
committerAnselm R Garbe <anselm@garbe.us>2009-07-09 19:58:58 +0100
commit87526be6f05ed892083d874c27f18b6c9e21881e (patch)
tree07a05c6309aa0c3416ef385725b5a8ff9e0a37e3
parent565050ac51687bbd4f388c6aeb2298db94430efb (diff)
downloaddwm-87526be6f05ed892083d874c27f18b6c9e21881e.tar.gz
added client number printing right of layout symbol
-rw-r--r--dwm.c14
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;