save floats patch
This commit is contained in:
parent
cb64871955
commit
a38e1a252f
17
dwm.c
17
dwm.c
@ -90,6 +90,7 @@ struct Client {
|
||||
char name[256];
|
||||
float mina, maxa;
|
||||
int x, y, w, h;
|
||||
int sfx, sfy, sfw, sfh; /* stored float geometry, used on mode revert */
|
||||
int oldx, oldy, oldw, oldh;
|
||||
int basew, baseh, incw, inch, maxw, maxh, minw, minh, hintsvalid;
|
||||
int bw, oldbw;
|
||||
@ -1142,6 +1143,10 @@ manage(Window w, XWindowAttributes *wa)
|
||||
updatewindowtype(c);
|
||||
updatesizehints(c);
|
||||
updatewmhints(c);
|
||||
c->sfx = c->x;
|
||||
c->sfy = c->y;
|
||||
c->sfw = c->w;
|
||||
c->sfh = c->h;
|
||||
{
|
||||
int format;
|
||||
unsigned long *data, n, extra;
|
||||
@ -1901,8 +1906,16 @@ togglefloating(const Arg *arg)
|
||||
return;
|
||||
selmon->sel->isfloating = !selmon->sel->isfloating || selmon->sel->isfixed;
|
||||
if (selmon->sel->isfloating)
|
||||
resize(selmon->sel, selmon->sel->x, selmon->sel->y,
|
||||
selmon->sel->w, selmon->sel->h, 0);
|
||||
/* restore last known float dimensions */
|
||||
resize(selmon->sel, selmon->sel->sfx, selmon->sel->sfy,
|
||||
selmon->sel->sfw, selmon->sel->sfh, False);
|
||||
else {
|
||||
/* save last known float dimensions */
|
||||
selmon->sel->sfx = selmon->sel->x;
|
||||
selmon->sel->sfy = selmon->sel->y;
|
||||
selmon->sel->sfw = selmon->sel->w;
|
||||
selmon->sel->sfh = selmon->sel->h;
|
||||
}
|
||||
|
||||
selmon->sel->x = selmon->sel->mon->mx + (selmon->sel->mon->mw - WIDTH(selmon->sel)) / 2;
|
||||
selmon->sel->y = selmon->sel->mon->my + (selmon->sel->mon->mh - HEIGHT(selmon->sel)) / 2;
|
||||
|
42
patches/behavior/dwm-savefloats-20181212-b69c870.diff
Normal file
42
patches/behavior/dwm-savefloats-20181212-b69c870.diff
Normal file
@ -0,0 +1,42 @@
|
||||
diff --git i/dwm.c w/dwm.c
|
||||
index 4465af1..96b0b26 100644
|
||||
--- i/dwm.c
|
||||
+++ w/dwm.c
|
||||
@@ -88,6 +88,7 @@ struct Client {
|
||||
char name[256];
|
||||
float mina, maxa;
|
||||
int x, y, w, h;
|
||||
+ int sfx, sfy, sfw, sfh; /* stored float geometry, used on mode revert */
|
||||
int oldx, oldy, oldw, oldh;
|
||||
int basew, baseh, incw, inch, maxw, maxh, minw, minh;
|
||||
int bw, oldbw;
|
||||
@@ -1056,6 +1057,10 @@ manage(Window w, XWindowAttributes *wa)
|
||||
updatewindowtype(c);
|
||||
updatesizehints(c);
|
||||
updatewmhints(c);
|
||||
+ c->sfx = c->x;
|
||||
+ c->sfy = c->y;
|
||||
+ c->sfw = c->w;
|
||||
+ c->sfh = c->h;
|
||||
XSelectInput(dpy, w, EnterWindowMask|FocusChangeMask|PropertyChangeMask|StructureNotifyMask);
|
||||
grabbuttons(c, 0);
|
||||
if (!c->isfloating)
|
||||
@@ -1714,8 +1719,16 @@ togglefloating(const Arg *arg)
|
||||
return;
|
||||
selmon->sel->isfloating = !selmon->sel->isfloating || selmon->sel->isfixed;
|
||||
if (selmon->sel->isfloating)
|
||||
- resize(selmon->sel, selmon->sel->x, selmon->sel->y,
|
||||
- selmon->sel->w, selmon->sel->h, 0);
|
||||
+ /* restore last known float dimensions */
|
||||
+ resize(selmon->sel, selmon->sel->sfx, selmon->sel->sfy,
|
||||
+ selmon->sel->sfw, selmon->sel->sfh, False);
|
||||
+ else {
|
||||
+ /* save last known float dimensions */
|
||||
+ selmon->sel->sfx = selmon->sel->x;
|
||||
+ selmon->sel->sfy = selmon->sel->y;
|
||||
+ selmon->sel->sfw = selmon->sel->w;
|
||||
+ selmon->sel->sfh = selmon->sel->h;
|
||||
+ }
|
||||
arrange(selmon);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user