Browse Source

fixed configurerequest according to the problem Jukka reported

config
Anselm R. Garbe 18 years ago
parent
commit
3167373512
1 changed files with 16 additions and 11 deletions
  1. +16
    -11
      event.c

+ 16
- 11
event.c View File

@ -165,6 +165,7 @@ buttonpress(XEvent *e) {
static void static void
configurerequest(XEvent *e) { configurerequest(XEvent *e) {
int x, y, w, h;
Client *c; Client *c;
XConfigureRequestEvent *ev = &e->xconfigurerequest; XConfigureRequestEvent *ev = &e->xconfigurerequest;
XWindowChanges wc; XWindowChanges wc;
@ -174,20 +175,24 @@ configurerequest(XEvent *e) {
if(ev->value_mask & CWBorderWidth) if(ev->value_mask & CWBorderWidth)
c->border = ev->border_width; c->border = ev->border_width;
if(c->isfixed || c->isfloat || (arrange == dofloat)) { 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)) if((ev->value_mask & (CWX | CWY))
&& !(ev->value_mask & (CWWidth | CWHeight))) && !(ev->value_mask & (CWWidth | CWHeight)))
{
c->x = x;
c->y = y;
configure(c); configure(c);
resize(c, c->x, c->y, c->w, c->h, False);
if(!isvisible(c))
ban(c);
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 else
configure(c); configure(c);


Loading…
Cancel
Save