- if((!c->isfloat && (arrange != dofloat))
- || ((ev->value_mask & (CWX|CWY)) && !(ev->value_mask & (CWWidth|CWHeight))))
- {
- configure(c);
- XSync(dpy, False);
- return;
+ if(c->isfixed || c->isfloat || (arrange == dofloat)) {
+ 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);
+ if(isvisible(c))
+ XMoveWindow(dpy, c->win, c->x, c->y);
+ }
+ else {
+ resize(c, x, y, w, h, False);
+ if(!isvisible(c))
+ ban(c);
+ }