avoid reverting the border if it's not necessary (avoids some flashing on view())
This commit is contained in:
		
							parent
							
								
									af8049bce8
								
							
						
					
					
						commit
						76d7e80fc4
					
				
							
								
								
									
										17
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								dwm.c
									
									
									
									
									
								
							| @ -179,7 +179,7 @@ static void setclientstate(Client *c, long state); | |||||||
| static void setlayout(const Arg *arg); | static void setlayout(const Arg *arg); | ||||||
| static void setmfact(const Arg *arg); | static void setmfact(const Arg *arg); | ||||||
| static void setup(void); | static void setup(void); | ||||||
| static void showhide(Client *c); | static void showhide(Client *c, unsigned int ntiled); | ||||||
| static void sigchld(int signal); | static void sigchld(int signal); | ||||||
| static void spawn(const Arg *arg); | static void spawn(const Arg *arg); | ||||||
| static void tag(const Arg *arg); | static void tag(const Arg *arg); | ||||||
| @ -283,7 +283,11 @@ applyrules(Client *c) { | |||||||
| 
 | 
 | ||||||
| void | void | ||||||
| arrange(void) { | arrange(void) { | ||||||
| 	showhide(stack); | 	unsigned int nt; | ||||||
|  | 	Client *c; | ||||||
|  | 
 | ||||||
|  | 	for(nt = 0, c = nexttiled(clients); c; c = nexttiled(c->next), nt++); | ||||||
|  | 	showhide(stack, nt); | ||||||
| 	focus(NULL); | 	focus(NULL); | ||||||
| 	if(lt[sellt]->arrange) | 	if(lt[sellt]->arrange) | ||||||
| 		lt[sellt]->arrange(); | 		lt[sellt]->arrange(); | ||||||
| @ -1341,18 +1345,19 @@ setup(void) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| showhide(Client *c) { | showhide(Client *c, unsigned int ntiled) { | ||||||
| 	if(!c) | 	if(!c) | ||||||
| 		return; | 		return; | ||||||
| 	if(ISVISIBLE(c)) { /* show clients top down */ | 	if(ISVISIBLE(c)) { /* show clients top down */ | ||||||
| 		adjustborder(c, borderpx); | 		if(ntiled > 1) /* avoid unnecessary border reverts */ | ||||||
|  | 			adjustborder(c, borderpx); | ||||||
| 		XMoveWindow(dpy, c->win, c->x, c->y); | 		XMoveWindow(dpy, c->win, c->x, c->y); | ||||||
| 		if(!lt[sellt]->arrange || c->isfloating) | 		if(!lt[sellt]->arrange || c->isfloating) | ||||||
| 			resize(c, c->x, c->y, c->w, c->h, True); | 			resize(c, c->x, c->y, c->w, c->h, True); | ||||||
| 		showhide(c->snext); | 		showhide(c->snext, ntiled); | ||||||
| 	} | 	} | ||||||
| 	else { /* hide clients bottom up */ | 	else { /* hide clients bottom up */ | ||||||
| 		showhide(c->snext); | 		showhide(c->snext, ntiled); | ||||||
| 		XMoveWindow(dpy, c->win, c->x + 2 * sw, c->y); | 		XMoveWindow(dpy, c->win, c->x + 2 * sw, c->y); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user