forked from mirror/dwm
fixed configurerequest according to the problem Jukka reported
This commit is contained in:
parent
4cff744438
commit
3167373512
1 changed files with 16 additions and 11 deletions
23
event.c
23
event.c
|
@ -165,6 +165,7 @@ buttonpress(XEvent *e) {
|
|||
|
||||
static void
|
||||
configurerequest(XEvent *e) {
|
||||
int x, y, w, h;
|
||||
Client *c;
|
||||
XConfigureRequestEvent *ev = &e->xconfigurerequest;
|
||||
XWindowChanges wc;
|
||||
|
@ -174,21 +175,25 @@ configurerequest(XEvent *e) {
|
|||
if(ev->value_mask & CWBorderWidth)
|
||||
c->border = ev->border_width;
|
||||
if(c->isfixed || c->isfloat || (arrange == dofloat)) {
|
||||
if(ev->value_mask & CWX)
|
||||
c->x = ev->x;
|
||||
if(ev->value_mask & CWY)
|
||||
c->y = ev->y;
|
||||
if(ev->value_mask & CWWidth)
|
||||
c->w = ev->width;
|
||||
if(ev->value_mask & CWHeight)
|
||||
c->h = ev->height;
|
||||
x = (ev->value_mask & CWX) ? ev->x : c->x;
|
||||
y = (ev->value_mask & CWY) ? ev->y : c->y;
|
||||
w = (ev->value_mask & CWWidth) ? ev->width : c->w;
|
||||
h = (ev->value_mask & CWHeight) ? ev->height : c->h;
|
||||
if((ev->value_mask & (CWX | CWY))
|
||||
&& !(ev->value_mask & (CWWidth | CWHeight)))
|
||||
{
|
||||
c->x = x;
|
||||
c->y = y;
|
||||
configure(c);
|
||||
resize(c, c->x, c->y, c->w, c->h, False);
|
||||
if(isvisible(c))
|
||||
XMoveWindow(dpy, c->win, c->x, c->y);
|
||||
}
|
||||
else {
|
||||
resize(c, x, y, w, h, False);
|
||||
if(!isvisible(c))
|
||||
ban(c);
|
||||
}
|
||||
}
|
||||
else
|
||||
configure(c);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue