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