mirror of git://git.suckless.org/dwm
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…
Reference in New Issue