fixed configurerequest according to the problem Jukka reported
authorAnselm R. Garbe <arg@suckless.org>
Mon, 19 Feb 2007 11:03:27 +0100
changeset 766 42cac13ec21e
parent 765 e4e7c6dc0785
child 767 074537180053
fixed configurerequest according to the problem Jukka reported
event.c
--- a/event.c	Mon Feb 19 10:51:11 2007 +0100
+++ b/event.c	Mon Feb 19 11:03:27 2007 +0100
@@ -165,6 +165,7 @@
 
 static void
 configurerequest(XEvent *e) {
+	int x, y, w, h;
 	Client *c;
 	XConfigureRequestEvent *ev = &e->xconfigurerequest;
 	XWindowChanges wc;
@@ -174,20 +175,24 @@
 		if(ev->value_mask & CWBorderWidth)
 			c->border = ev->border_width;
 		if(c->isfixed || c->isfloat || (arrange == dofloat)) {
-			if(ev->value_mask & CWX)
-				c->x = ev->x;
-			if(ev->value_mask & CWY)
-				c->y = ev->y;
-			if(ev->value_mask & CWWidth)
-				c->w = ev->width;
-			if(ev->value_mask & CWHeight)
-				c->h = ev->height;
+			x = (ev->value_mask & CWX) ? ev->x : c->x;
+			y = (ev->value_mask & CWY) ? ev->y : c->y;
+			w = (ev->value_mask & CWWidth) ? ev->width : c->w;
+			h = (ev->value_mask & CWHeight) ? ev->height : c->h;
 			if((ev->value_mask & (CWX | CWY))
 			&& !(ev->value_mask & (CWWidth | CWHeight)))
+			{
+				c->x = x;
+				c->y = y;
 				configure(c);
-			resize(c, c->x, c->y, c->w, c->h, False);
-			if(!isvisible(c))
-				ban(c);
+				if(isvisible(c))
+					XMoveWindow(dpy, c->win, c->x, c->y);
+			}
+			else {
+				resize(c, x, y, w, h, False);
+				if(!isvisible(c))
+					ban(c);
+			}
 		}
 		else
 			configure(c);