mirror of
https://github.com/leahneukirchen/cwm.git
synced 2023-08-10 21:13:12 +03:00
extend client_resize so that it can know when to reset max flags and
bwidth; this allows a client to be resized from a max state, which now gets treated like a non-max'd client. based on a diff that does part of this in a different way from Alexander Polakov.
This commit is contained in:
parent
7071261bde
commit
86524e21dd
2
calmwm.h
2
calmwm.h
@ -327,7 +327,7 @@ struct client_ctx *client_new(Window, struct screen_ctx *, int);
|
|||||||
void client_ptrsave(struct client_ctx *);
|
void client_ptrsave(struct client_ctx *);
|
||||||
void client_ptrwarp(struct client_ctx *);
|
void client_ptrwarp(struct client_ctx *);
|
||||||
void client_raise(struct client_ctx *);
|
void client_raise(struct client_ctx *);
|
||||||
void client_resize(struct client_ctx *);
|
void client_resize(struct client_ctx *, int);
|
||||||
void client_send_delete(struct client_ctx *);
|
void client_send_delete(struct client_ctx *);
|
||||||
void client_setactive(struct client_ctx *, int);
|
void client_setactive(struct client_ctx *, int);
|
||||||
void client_setname(struct client_ctx *);
|
void client_setname(struct client_ctx *);
|
||||||
|
13
client.c
13
client.c
@ -306,7 +306,7 @@ client_maximize(struct client_ctx *cc)
|
|||||||
cc->flags |= CLIENT_MAXIMIZED;
|
cc->flags |= CLIENT_MAXIMIZED;
|
||||||
|
|
||||||
resize:
|
resize:
|
||||||
client_resize(cc);
|
client_resize(cc, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -355,7 +355,7 @@ client_vertmaximize(struct client_ctx *cc)
|
|||||||
cc->flags |= CLIENT_VMAXIMIZED;
|
cc->flags |= CLIENT_VMAXIMIZED;
|
||||||
|
|
||||||
resize:
|
resize:
|
||||||
client_resize(cc);
|
client_resize(cc, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -404,12 +404,17 @@ client_horizmaximize(struct client_ctx *cc)
|
|||||||
cc->flags |= CLIENT_HMAXIMIZED;
|
cc->flags |= CLIENT_HMAXIMIZED;
|
||||||
|
|
||||||
resize:
|
resize:
|
||||||
client_resize(cc);
|
client_resize(cc, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
client_resize(struct client_ctx *cc)
|
client_resize(struct client_ctx *cc, int reset)
|
||||||
{
|
{
|
||||||
|
if (reset) {
|
||||||
|
cc->flags &= ~CLIENT_MAXIMIZED;
|
||||||
|
cc->bwidth = Conf.bwidth;
|
||||||
|
}
|
||||||
|
|
||||||
client_draw_border(cc);
|
client_draw_border(cc);
|
||||||
|
|
||||||
XMoveResizeWindow(X_Dpy, cc->win, cc->geom.x,
|
XMoveResizeWindow(X_Dpy, cc->win, cc->geom.x,
|
||||||
|
2
kbfunc.c
2
kbfunc.c
@ -117,7 +117,7 @@ kbfunc_moveresize(struct client_ctx *cc, union arg *arg)
|
|||||||
cc->geom.h = 1;
|
cc->geom.h = 1;
|
||||||
if ((cc->geom.w += mx) < 1)
|
if ((cc->geom.w += mx) < 1)
|
||||||
cc->geom.w = 1;
|
cc->geom.w = 1;
|
||||||
client_resize(cc);
|
client_resize(cc, 1);
|
||||||
|
|
||||||
/* Make sure the pointer stays within the window. */
|
/* Make sure the pointer stays within the window. */
|
||||||
xu_ptr_getpos(cc->win, &cc->ptr.x, &cc->ptr.y);
|
xu_ptr_getpos(cc->win, &cc->ptr.x, &cc->ptr.y);
|
||||||
|
@ -110,12 +110,12 @@ mousefunc_window_resize(struct client_ctx *cc, void *arg)
|
|||||||
/* don't resize more than 60 times / second */
|
/* don't resize more than 60 times / second */
|
||||||
if ((ev.xmotion.time - ltime) > (1000 / 60)) {
|
if ((ev.xmotion.time - ltime) > (1000 / 60)) {
|
||||||
ltime = ev.xmotion.time;
|
ltime = ev.xmotion.time;
|
||||||
client_resize(cc);
|
client_resize(cc, 1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ButtonRelease:
|
case ButtonRelease:
|
||||||
if (ltime)
|
if (ltime)
|
||||||
client_resize(cc);
|
client_resize(cc, 1);
|
||||||
XUnmapWindow(X_Dpy, sc->menuwin);
|
XUnmapWindow(X_Dpy, sc->menuwin);
|
||||||
XReparentWindow(X_Dpy, sc->menuwin, sc->rootwin, 0, 0);
|
XReparentWindow(X_Dpy, sc->menuwin, sc->rootwin, 0, 0);
|
||||||
xu_ptr_ungrab();
|
xu_ptr_ungrab();
|
||||||
|
Loading…
Reference in New Issue
Block a user