fixed configurerequest according to the problem Jukka reported
This commit is contained in:
		
							
								
								
									
										23
									
								
								event.c
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								event.c
									
									
									
									
									
								
							| @@ -165,6 +165,7 @@ buttonpress(XEvent *e) { | ||||
|  | ||||
| static void | ||||
| configurerequest(XEvent *e) { | ||||
| 	int x, y, w, h; | ||||
| 	Client *c; | ||||
| 	XConfigureRequestEvent *ev = &e->xconfigurerequest; | ||||
| 	XWindowChanges wc; | ||||
| @@ -174,21 +175,25 @@ configurerequest(XEvent *e) { | ||||
| 		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)) | ||||
| 					XMoveWindow(dpy, c->win, c->x, c->y); | ||||
| 			} | ||||
| 			else { | ||||
| 				resize(c, x, y, w, h, False); | ||||
| 				if(!isvisible(c)) | ||||
| 					ban(c); | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| 			configure(c); | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user