JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
fixed some other comments, now also the code side seems to be at a level to be review...
[dwm.git] / event.c
diff --git a/event.c b/event.c
index a719bf2..74ae276 100644 (file)
--- a/event.c
+++ b/event.c
@@ -109,19 +109,17 @@ buttonpress(XEvent *e)
                for(a.i = 0; a.i < ntags; a.i++) {
                        x += textw(tags[a.i]);
                        if(ev->x < x) {
-                               switch(ev->button) {
-                               case Button1:
+                               if(ev->button == Button1) {
                                        if(ev->state & MODKEY)
                                                tag(&a);
                                        else
                                                view(&a);
-                                       break;
-                               case Button3:
+                               }
+                               else if(ev->button == Button3) {
                                        if(ev->state & MODKEY)
                                                toggletag(&a);
                                        else
                                                toggleview(&a);
-                                       break;
                                }
                                return;
                        }
@@ -133,26 +131,17 @@ buttonpress(XEvent *e)
        }
        else if((c = getclient(ev->window))) {
                focus(c);
-               if(CLEANMASK(ev->state) != MODKEY)
+               if(maximized || CLEANMASK(ev->state) != MODKEY)
                        return;
-               switch(ev->button) {
-               default:
-                       break;
-               case Button1:
-                       if(!c->ismax && (arrange == dofloat || c->isfloat)) {
-                               restack(c);
-                               movemouse(c);
-                       }
-                       break;
-               case Button2:
+               if(ev->button == Button1 && (arrange == dofloat || c->isfloat)) {
+                       restack(c);
+                       movemouse(c);
+               }
+               else if(ev->button == Button2)
                        zoom(NULL);
-                       break;
-               case Button3:
-                       if(!c->ismax && (arrange == dofloat || c->isfloat)) {
-                               restack(c);
-                               resizemouse(c);
-                       }
-                       break;
+               else if(ev->button == Button3 && (arrange == dofloat || c->isfloat)) {
+                       restack(c);
+                       resizemouse(c);
                }
        }
 }
@@ -184,7 +173,7 @@ configurerequest(XEvent *e)
        XWindowChanges wc;
 
        if((c = getclient(ev->window))) {
-               if(!c->isfloat && (arrange != dofloat) && c->ismax) {
+               if((c == sel) && !c->isfloat && (arrange != dofloat) && maximized) {
                        synconfig(c, sx, sy + bh, sw - 2, sh - 2 - bh, ev->border_width);
                        XSync(dpy, False);
                        return;
@@ -354,11 +343,11 @@ propertynotify(XEvent *e)
                                        arrange(NULL);
                                break;
                        case XA_WM_NORMAL_HINTS:
-                               setsize(c);
+                               updatesize(c);
                                break;
                }
                if(ev->atom == XA_WM_NAME || ev->atom == netatom[NetWMName]) {
-                       settitle(c);
+                       updatetitle(c);
                        drawtitle(c);
                }
        }