sanders solution is convincing and elegant
This commit is contained in:
		
							
								
								
									
										8
									
								
								client.c
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								client.c
									
									
									
									
									
								
							| @@ -99,14 +99,6 @@ focus(Client *c) | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	if(c) { | 	if(c) { | ||||||
| 		if((c->isfloat || arrange == dofloat) && (c != clients)) { |  | ||||||
| 			detach(c); |  | ||||||
| 			if(clients) { |  | ||||||
| 				clients->prev = c; |  | ||||||
| 				c->next = clients; |  | ||||||
| 			} |  | ||||||
| 			clients = c; |  | ||||||
| 		} |  | ||||||
| 		grabbuttons(c, True); | 		grabbuttons(c, True); | ||||||
| 		drawtitle(c); | 		drawtitle(c); | ||||||
| 		XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); | 		XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); | ||||||
|   | |||||||
							
								
								
									
										46
									
								
								view.c
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								view.c
									
									
									
									
									
								
							| @@ -215,52 +215,20 @@ resizecol(Arg *arg) | |||||||
| void | void | ||||||
| restack() | restack() | ||||||
| { | { | ||||||
| 	static unsigned int nwins = 0; |  | ||||||
| 	static Window *wins = NULL; |  | ||||||
| 	unsigned int f, fi, m, mi, n; |  | ||||||
| 	Client *c; | 	Client *c; | ||||||
| 	XEvent ev; | 	XEvent ev; | ||||||
| 	 | 	 | ||||||
| 	for(f = 0, m = 0, c = clients; c; c = c->next) | 	if(!sel) | ||||||
| 		if(isvisible(c)) { |  | ||||||
| 			if(c->isfloat || arrange == dofloat) |  | ||||||
| 				f++; |  | ||||||
| 			else |  | ||||||
| 				m++; |  | ||||||
| 		} |  | ||||||
| 	if(!(n = 2 * (f + m))) { |  | ||||||
| 		drawstatus(); |  | ||||||
| 		return; | 		return; | ||||||
| 	} |  | ||||||
| 	if(nwins < n) { |  | ||||||
| 		nwins = n; |  | ||||||
| 		wins = erealloc(wins, nwins * sizeof(Window)); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	fi = 0; |  | ||||||
| 	mi = 2 * f; |  | ||||||
| 	if(sel) { |  | ||||||
| 	if(sel->isfloat || arrange == dofloat) { | 	if(sel->isfloat || arrange == dofloat) { | ||||||
| 			wins[fi++] = sel->twin; | 		XRaiseWindow(dpy, sel->win); | ||||||
| 			wins[fi++] = sel->win; | 		XRaiseWindow(dpy, sel->twin); | ||||||
| 	} | 	} | ||||||
| 		else { | 	if(arrange != dofloat)  | ||||||
| 			wins[mi++] = sel->twin; | 		for(c = nexttiled(clients); c; c = nexttiled(c->next)) { | ||||||
| 			wins[mi++] = sel->win; | 			XLowerWindow(dpy, c->twin); | ||||||
|  | 			XLowerWindow(dpy, c->win); | ||||||
| 		} | 		} | ||||||
| 	} |  | ||||||
| 	for(c = clients; c; c = c->next) |  | ||||||
| 		if(isvisible(c) && c != sel) { |  | ||||||
| 			if(c->isfloat || arrange == dofloat) { |  | ||||||
| 				wins[fi++] = c->twin; |  | ||||||
| 				wins[fi++] = c->win; |  | ||||||
| 			} |  | ||||||
| 			else { |  | ||||||
| 				wins[mi++] = c->twin; |  | ||||||
| 				wins[mi++] = c->win; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	XRestackWindows(dpy, wins, n); |  | ||||||
| 	drawall(); | 	drawall(); | ||||||
| 	XSync(dpy, False); | 	XSync(dpy, False); | ||||||
| 	while(XCheckMaskEvent(dpy, EnterWindowMask, &ev)); | 	while(XCheckMaskEvent(dpy, EnterWindowMask, &ev)); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user