[wiki] [sites] [dwm] Add 6.1 version of resizecorners patch || Klemens Nanni

From: <git_AT_suckless.org>
Date: Wed, 17 Feb 2016 09:23:48 +0100

commit f4621eac6899b2a3b489e5826c2bc00ae25ac51b
Author: Klemens Nanni <kl3_AT_posteo.org>
Date: Wed Feb 17 09:23:45 2016 +0100

    [dwm] Add 6.1 version of resizecorners patch

diff --git a/dwm.suckless.org/patches/dwm-6.1-resizecorners.diff b/dwm.suckless.org/patches/dwm-6.1-resizecorners.diff
new file mode 100644
index 0000000..b4c8400
--- /dev/null
+++ b/dwm.suckless.org/patches/dwm-6.1-resizecorners.diff
_AT_@ -0,0 +1,68 @@
+diff --git a/dwm.c b/dwm.c
+index ff7e096..b6ce27c 100644
+--- a/dwm.c
++++ b/dwm.c
+_AT_@ -1313,9 +1313,14 @@ void
+ resizemouse(const Arg *arg)
+ {
+ int ocx, ocy, nw, nh;
++ int ocx2, ocy2, nx, ny;
+ Client *c;
+ Monitor *m;
+ XEvent ev;
++ int horizcorner, vertcorner;
++ int di;
++ unsigned int dui;
++ Window dummy;
+ Time lasttime = 0;
+
+ if (!(c = selmon->sel))
+_AT_@ -1325,10 +1330,19 @@ resizemouse(const Arg *arg)
+ restack(selmon);
+ ocx = c->x;
+ ocy = c->y;
++ ocx2 = c->x + c->w;
++ ocy2 = c->y + c->h;
+ if (XGrabPointer(dpy, root, False, MOUSEMASK, GrabModeAsync, GrabModeAsync,
+ None, cursor[CurResize]->cursor, CurrentTime) != GrabSuccess)
+ return;
+- XWarpPointer(dpy, None, c->win, 0, 0, 0, 0, c->w + c->bw - 1, c->h + c->bw - 1);
++ if (!XQueryPointer (dpy, c->win, &dummy, &dummy, &di, &di, &nx, &ny, &dui))
++ return;
++ horizcorner = nx < c->w / 2;
++ vertcorner = ny < c->h / 2;
++ XWarpPointer (dpy, None, c->win, 0, 0, 0, 0,
++ horizcorner ? (-c->bw) : (c->w + c->bw - 1),
++ vertcorner ? (-c->bw) : (c->h + c->bw - 1));
++
+ do {
+ XMaskEvent(dpy, MOUSEMASK|ExposureMask|SubstructureRedirectMask, &ev);
+ switch(ev.type) {
+_AT_@ -1344,6 +1358,11 @@ resizemouse(const Arg *arg)
+
+ nw = MAX(ev.xmotion.x - ocx - 2 * c->bw + 1, 1);
+ nh = MAX(ev.xmotion.y - ocy - 2 * c->bw + 1, 1);
++ nx = horizcorner ? ev.xmotion.x : c->x;
++ ny = vertcorner ? ev.xmotion.y : c->y;
++ nw = MAX(horizcorner ? (ocx2 - nx) : (ev.xmotion.x - ocx - 2 * c->bw + 1), 1);
++ nh = MAX(vertcorner ? (ocy2 - ny) : (ev.xmotion.y - ocy - 2 * c->bw + 1), 1);
++
+ if (c->mon->wx + nw >= selmon->wx && c->mon->wx + nw <= selmon->wx + selmon->ww
+ && c->mon->wy + nh >= selmon->wy && c->mon->wy + nh <= selmon->wy + selmon->wh)
+ {
+_AT_@ -1352,11 +1371,13 @@ resizemouse(const Arg *arg)
+ togglefloating(NULL);
+ }
+ if (!selmon->lt[selmon->sellt]->arrange || c->isfloating)
+- resize(c, c->x, c->y, nw, nh, 1);
++ resize(c, nx, ny, nw, nh, 1);
+ break;
+ }
+ } while (ev.type != ButtonRelease);
+- XWarpPointer(dpy, None, c->win, 0, 0, 0, 0, c->w + c->bw - 1, c->h + c->bw - 1);
++ XWarpPointer(dpy, None, c->win, 0, 0, 0, 0,
++ horizcorner ? (-c->bw) : (c->w + c->bw - 1),
++ vertcorner ? (-c->bw) : (c->h + c->bw - 1));
+ XUngrabPointer(dpy, CurrentTime);
+ while (XCheckMaskEvent(dpy, EnterWindowMask, &ev));
+ if ((m = recttomon(c->x, c->y, c->w, c->h)) != selmon) {
diff --git a/dwm.suckless.org/patches/resizecorners.md b/dwm.suckless.org/patches/resizecorners.md
index ee1eb26..502f509 100644
--- a/dwm.suckless.org/patches/resizecorners.md
+++ b/dwm.suckless.org/patches/resizecorners.md
_AT_@ -6,8 +6,10 @@ By default, windows only from the bottom right corner. With this Patch, the mous
 
 ## Download
 
+ * [dwm-6.1-resizecorners.diff](dwm-6.1-resizecorners.diff) (17.02.2016)
  * [dwm-6.0-resizecorners.diff](dwm-6.0-resizecorners.diff) (12.05.2015)
 
 ## Author
 
  * dusty - <dusty_AT_teknik.io>
+ * Klemens Nanni <[kl3_AT_posteo.org](mailto:kl3_AT_posteo.org)> (6.1 version)
Received on Wed Feb 17 2016 - 09:23:48 CET

This archive was generated by hypermail 2.3.0 : Wed Feb 17 2016 - 09:24:14 CET