some hotfix cleanup related to wild selmon-> destruction
This commit is contained in:
		
							
								
								
									
										35
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								dwm.c
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| #define XINULATOR /* debug, simulates dual head */ | //#define XINULATOR /* debug, simulates dual head */ | ||||||
| /* See LICENSE file for copyright and license details. | /* See LICENSE file for copyright and license details. | ||||||
|  * |  * | ||||||
|  * dynamic window manager is designed like any other X client as well. It is |  * dynamic window manager is designed like any other X client as well. It is | ||||||
| @@ -1649,9 +1649,11 @@ updatebarpos(Monitor *m) { | |||||||
|  |  | ||||||
| void | void | ||||||
| updategeom(void) { | updategeom(void) { | ||||||
| 	int i, n = 1; | 	int i, di, n = 1, x, y; | ||||||
|  | 	unsigned int dui; | ||||||
| 	Client *c; | 	Client *c; | ||||||
| 	Monitor *newmons = NULL, *m, *tm; | 	Monitor *newmons = NULL, *m, *tm; | ||||||
|  | 	Window dummy; | ||||||
|  |  | ||||||
| #ifdef XINULATOR | #ifdef XINULATOR | ||||||
| 	n = 2; | 	n = 2; | ||||||
| @@ -1720,16 +1722,6 @@ updategeom(void) { | |||||||
| 		m->showbar = showbar; | 		m->showbar = showbar; | ||||||
| 		m->topbar = topbar; | 		m->topbar = topbar; | ||||||
| 		updatebarpos(m); | 		updatebarpos(m); | ||||||
| 		/* reassign all clients with same screen number */ |  | ||||||
| 		for(tm = mons; tm; tm = tm->next) |  | ||||||
| 			if(tm->screen_number == m->screen_number) { |  | ||||||
| 				m->clients = tm->clients; |  | ||||||
| 				m->sel = m->stack = tm->stack; |  | ||||||
| 				tm->clients = NULL; |  | ||||||
| 				tm->stack = NULL; |  | ||||||
| 				for(c = m->clients; c; c = c->next) |  | ||||||
| 					c->mon = m; |  | ||||||
| 			} |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* reassign left over clients of disappeared monitors */ | 	/* reassign left over clients of disappeared monitors */ | ||||||
| @@ -1744,18 +1736,13 @@ updategeom(void) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* select focused monitor */ | 	/* select focused monitor */ | ||||||
| 	if(!selmon) { | 	selmon = newmons; | ||||||
| 		selmon = newmons; | 	if(XQueryPointer(dpy, root, &dummy, &dummy, &x, &y, &di, &di, &dui))  | ||||||
| 		int di, x, y; | 		for(m = newmons; m; m = m->next) | ||||||
| 		unsigned int dui; | 			if(INRECT(x, y, m->wx, m->wy, m->ww, m->wh)) { | ||||||
| 		Window dummy; | 				selmon = m; | ||||||
| 		if(XQueryPointer(dpy, root, &dummy, &dummy, &x, &y, &di, &di, &dui))  | 				break; | ||||||
| 			for(m = newmons; m; m = m->next) | 			} | ||||||
| 				if(INRECT(x, y, m->wx, m->wy, m->ww, m->wh)) { |  | ||||||
| 					selmon = m; |  | ||||||
| 					break; |  | ||||||
| 				} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/* final assignment of new monitors */ | 	/* final assignment of new monitors */ | ||||||
| 	cleanupmons(); | 	cleanupmons(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Anselm R Garbe
					Anselm R Garbe