JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
Button3 click on mode label toggles stack position now
[dwm.git] / event.c
diff --git a/event.c b/event.c
index cf89428..a17034c 100644 (file)
--- a/event.c
+++ b/event.c
@@ -38,6 +38,7 @@ movemouse(Client *c) {
                XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
                switch (ev.type) {
                case ButtonRelease:
+                       resize(c, True, TopLeft);
                        XUngrabPointer(dpy, CurrentTime);
                        return;
                case Expose:
@@ -71,6 +72,7 @@ resizemouse(Client *c) {
                XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
                switch(ev.type) {
                case ButtonRelease:
+                       resize(c, True, TopLeft);
                        XUngrabPointer(dpy, CurrentTime);
                        return;
                case Expose:
@@ -124,6 +126,8 @@ buttonpress(XEvent *e) {
                if(ev->x < x + bmw) {
                        if(ev->button == Button1)
                                togglemode(NULL);
+                       else if(ev->button == Button3)
+                               togglestackpos(NULL);
                }
        }
        else if((c = getclient(ev->window))) {
@@ -148,7 +152,6 @@ configurerequest(XEvent *e) {
        unsigned long newmask;
        Client *c;
        XConfigureRequestEvent *ev = &e->xconfigurerequest;
-       XEvent synev;
        XWindowChanges wc;
 
        if((c = getclient(ev->window))) {
@@ -172,22 +175,14 @@ configurerequest(XEvent *e) {
                newmask = ev->value_mask & (~(CWSibling | CWStackMode | CWBorderWidth));
                if(newmask)
                        XConfigureWindow(dpy, c->win, newmask, &wc);
-               else {
-                       synev.type = ConfigureNotify;
-                       synev.xconfigure.display = dpy;
-                       synev.xconfigure.event = c->win;
-                       synev.xconfigure.window = c->win;
-                       synev.xconfigure.x = c->x;
-                       synev.xconfigure.y = c->y;
-                       synev.xconfigure.width = c->w;
-                       synev.xconfigure.height = c->h;
-                       synev.xconfigure.border_width = c->border;
-                       synev.xconfigure.above = None;
-                       XSendEvent(dpy, c->win, True, NoEventMask, &synev);
-               }
+               else
+                       configure(c);
                XSync(dpy, False);
-               if(c->isfloat)
+               if(c->isfloat) {
                        resize(c, False, TopLeft);
+                       if(!isvisible(c))
+                               ban(c);
+               }
                else
                        arrange(NULL);
        }
@@ -326,6 +321,7 @@ propertynotify(XEvent *e) {
                }
                if(ev->atom == XA_WM_NAME || ev->atom == netatom[NetWMName]) {
                        updatetitle(c);
+                       resizetitle(c);
                        drawtitle(c);
                }
        }