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