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 | static void | ||||||
| configurerequest(XEvent *e) { | configurerequest(XEvent *e) { | ||||||
|  | 	int x, y, w, h; | ||||||
| 	Client *c; | 	Client *c; | ||||||
| 	XConfigureRequestEvent *ev = &e->xconfigurerequest; | 	XConfigureRequestEvent *ev = &e->xconfigurerequest; | ||||||
| 	XWindowChanges wc; | 	XWindowChanges wc; | ||||||
| @@ -174,21 +175,25 @@ configurerequest(XEvent *e) { | |||||||
| 		if(ev->value_mask & CWBorderWidth) | 		if(ev->value_mask & CWBorderWidth) | ||||||
| 			c->border = ev->border_width; | 			c->border = ev->border_width; | ||||||
| 		if(c->isfixed || c->isfloat || (arrange == dofloat)) { | 		if(c->isfixed || c->isfloat || (arrange == dofloat)) { | ||||||
| 			if(ev->value_mask & CWX) | 			x = (ev->value_mask & CWX) ? ev->x : c->x; | ||||||
| 				c->x = ev->x; | 			y = (ev->value_mask & CWY) ? ev->y : c->y; | ||||||
| 			if(ev->value_mask & CWY) | 			w = (ev->value_mask & CWWidth) ? ev->width : c->w; | ||||||
| 				c->y = ev->y; | 			h = (ev->value_mask & CWHeight) ? ev->height : c->h; | ||||||
| 			if(ev->value_mask & CWWidth) |  | ||||||
| 				c->w = ev->width; |  | ||||||
| 			if(ev->value_mask & CWHeight) |  | ||||||
| 				c->h = ev->height; |  | ||||||
| 			if((ev->value_mask & (CWX | CWY)) | 			if((ev->value_mask & (CWX | CWY)) | ||||||
| 			&& !(ev->value_mask & (CWWidth | CWHeight))) | 			&& !(ev->value_mask & (CWWidth | CWHeight))) | ||||||
|  | 			{ | ||||||
|  | 				c->x = x; | ||||||
|  | 				c->y = y; | ||||||
| 				configure(c); | 				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)) | 				if(!isvisible(c)) | ||||||
| 					ban(c); | 					ban(c); | ||||||
| 			} | 			} | ||||||
|  | 		} | ||||||
| 		else | 		else | ||||||
| 			configure(c); | 			configure(c); | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user