fixed tag click handling, however ClkRootWin doesn't work for me
authorAnselm R Garbe <garbeam@gmail.com>
Thu, 12 Jun 2008 22:04:55 +0000 (23:04 +0100)
committerAnselm R Garbe <garbeam@gmail.com>
Thu, 12 Jun 2008 22:04:55 +0000 (23:04 +0100)
dwm.c

diff --git a/dwm.c b/dwm.c
index d5319657bd916c5be35d0d2c2be31e82efe73b9c..d13a7a2a20900955623e0ea981ba5b80a5e6c93c 100644 (file)
--- a/dwm.c
+++ b/dwm.c
@@ -59,8 +59,8 @@ enum { CurNormal, CurResize, CurMove, CurLast };        /* cursor */
 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 @@ buttonpress(XEvent *e) {
 
        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))