about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorAnselm R.Garbe <arg@10ksloc.org>2006-08-16 17:56:04 +0200
committerAnselm R.Garbe <arg@10ksloc.org>2006-08-16 17:56:04 +0200
commitad2e77d6350b1f43513d052018735d2a8f949d78 (patch)
tree85e55198b8bf2c86f77d926d7e190b211630fd38
parenta20b10d01fab9e844ba7cd2cf694b45f61b89f7c (diff)
downloaddwm-ad2e77d6350b1f43513d052018735d2a8f949d78.tar.gz
fixed issue reported by sander
-rw-r--r--client.c4
-rw-r--r--tag.c5
2 files changed, 6 insertions, 3 deletions
diff --git a/client.c b/client.c
index 269bf8c..050e8a3 100644
--- a/client.c
+++ b/client.c
@@ -261,6 +261,10 @@ manage(Window w, XWindowAttributes *wa)
 	if(trans && (tc = getclient(trans))) {
 		c->x = (tc->x + tc->w / 2) - (c->w / 2);
 		c->y = (tc->y + tc->h / 2) - (c->h / 2);
+		if(c->x < 0 || c->x >= sw)
+			c->x = (sw / 2) - (c->w / 2);
+		if(c->y < 0 || c->y >= sh)
+			c->y = ((sh - bh) / 2) - (c->h / 2) + bh;
 	}
 	else {
 		c->x = (sw / 2) - (c->w / 2);
diff --git a/tag.c b/tag.c
index 841d0fc..cdb0f52 100644
--- a/tag.c
+++ b/tag.c
@@ -49,12 +49,11 @@ dofloat(Arg *arg)
 	}
 	if(!sel || !isvisible(sel))
 		sel = getnext(clients);
-	if(sel) {
+	if(sel)
 		focus(sel);
-		restack();
-	}
 	else
 		XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime);
+	restack();
 }
 
 void