about summary refs log tree commit diff stats
path: root/dwm.c
diff options
context:
space:
mode:
authorAnselm R Garbe <garbeam@gmail.com>2008-02-11 20:43:41 +0000
committerAnselm R Garbe <garbeam@gmail.com>2008-02-11 20:43:41 +0000
commitc619363d1580d5913b00d8b7d0415da5917b8060 (patch)
treef9d7ee81200f0273c1800a69c3d2db5fd6d9f756 /dwm.c
parent012710a3cee6a15e4b8284edb57d39332ddd60b4 (diff)
downloaddwm-c619363d1580d5913b00d8b7d0415da5917b8060.tar.gz
applied dwm-4.8-snaptileds.diff
Diffstat (limited to 'dwm.c')
-rw-r--r--dwm.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/dwm.c b/dwm.c
index 5814844..699aed1 100644
--- a/dwm.c
+++ b/dwm.c
@@ -368,23 +368,16 @@ buttonpress(XEvent *e) {
 		if(CLEANMASK(ev->state) != MODKEY)
 			return;
 		if(ev->button == Button1) {
-			if((m->layout->arrange == floating) || c->isfloating)
-				restack();
-			else
-				togglefloating(NULL);
+			restack();
 			movemouse(c);
 		}
 		else if(ev->button == Button2) {
 			if((floating != m->layout->arrange) && c->isfloating)
 				togglefloating(NULL);
-			else
-				zoom(NULL);
+			zoom(NULL);
 		}
 		else if(ev->button == Button3 && !c->isfixed) {
-			if((floating == m->layout->arrange) || c->isfloating)
-				restack();
-			else
-				togglefloating(NULL);
+			restack();
 			resizemouse(c);
 		}
 	}
@@ -1195,7 +1188,10 @@ movemouse(Client *c) {
 				ny = m->way;
 			else if(abs((m->way + m->wah) - (ny + c->h + 2 * c->border)) < SNAP)
 				ny = m->way + m->wah - c->h - 2 * c->border;
-			resize(c, nx, ny, c->w, c->h, False);
+			if((monitors[selmonitor].layout->arrange != floating) && (abs(nx - c->x) > SNAP || abs(ny - c->y) > SNAP))
+				togglefloating(NULL);
+			if((monitors[selmonitor].layout->arrange == floating) || c->isfloating)
+				resize(c, nx, ny, c->w, c->h, False);
 			memcpy(c->tags, monitors[monitorat()].seltags, sizeof initags);
 			break;
 		}
@@ -1358,7 +1354,10 @@ resizemouse(Client *c) {
 				nw = 1;
 			if((nh = ev.xmotion.y - ocy - 2 * c->border + 1) <= 0)
 				nh = 1;
-			resize(c, c->x, c->y, nw, nh, True);
+			if((monitors[selmonitor].layout->arrange != floating) && (abs(nw - c->w) > SNAP || abs(nh - c->h) > SNAP))
+				togglefloating(NULL);
+			if((monitors[selmonitor].layout->arrange == floating) || c->isfloating)
+				resize(c, c->x, c->y, nw, nh, True);
 			break;
 		}
 	}