fixed tag click handling, however ClkRootWin doesn't work for me
authorAnselm R Garbe <garbeam@gmail.com>
Thu, 12 Jun 2008 23:04:55 +0100 (2008-06-12)
changeset 1273 10c33b081850
parent 1272 2891dfa9f3a4
child 1274 e4f5c48e92ec
fixed tag click handling, however ClkRootWin doesn't work for me
dwm.c
--- a/dwm.c	Thu Jun 12 16:37:03 2008 +0100
+++ b/dwm.c	Thu Jun 12 23:04:55 2008 +0100
@@ -59,8 +59,8 @@
 enum { ColBorder, ColFG, ColBG, ColLast };              /* color */
 enum { NetSupported, NetWMName, NetLast };              /* EWMH atoms */
 enum { WMProtocols, WMDelete, WMName, WMState, WMLast };/* default atoms */
-enum { ClkLtSymbol = -1, ClkStatusText = -2, ClkWinTitle = -3,
-       ClkClientWin = -4, ClkRootWin = -5, ClkLast = -6};/* clicks */
+enum { ClkLtSymbol = 64, ClkStatusText, ClkWinTitle,
+       ClkClientWin, ClkRootWin, ClkLast };             /* clicks */
 
 /* typedefs */
 typedef unsigned int uint;
@@ -314,11 +314,12 @@
 
 	click = ClkRootWin;
 	if(ev->window == barwin) {
-		x = 0;
-		for(i = 0; i < LENGTH(tags) && ev->x >= x; i++)
+		i = x = 0;
+		do
 			x += TEXTW(tags[i]);
-		if(i < LENGTH(tags) || ev->x <= x)
-			click = i - 1;
+		while(ev->x >= x && ++i < LENGTH(tags));
+		if(i < LENGTH(tags))
+			click = i;
 		else if(ev->x < x + blw)
 			click = ClkLtSymbol;
 		else if(ev->x > wx + ww - TEXTW(stext))