X-Git-Url: https://git.xinqibao.xyz/dwm.git/blobdiff_plain/67c2124fa9962743fd7406953506dabce282683c..b43989207a949cbc17182b451aa527afe542c98f:/client.c

diff --git a/client.c b/client.c
index 0309eac..dff398a 100644
--- a/client.c
+++ b/client.c
@@ -203,8 +203,14 @@ manage(Window w, XWindowAttributes *wa)
 	c->border = 0;
 	setsize(c);
 
+	if(c->x + c->w + 2 > sw)
+		c->x = sw - c->w - 2;
+	if(c->x < 0)
+		c->x = 0;
+	if(c->y + c->h + 2 > sh)
+		c->y = sh - c->h - 2;
 	if(c->h != sh && c->y < bh)
-		c->y = c->ty = bh;
+		c->y = bh;
 
 	c->proto = getproto(c->win);
 	XSelectInput(dpy, c->win,
@@ -257,20 +263,6 @@ manage(Window w, XWindowAttributes *wa)
 			|| (c->maxw && c->minw &&
 				c->maxw == c->minw && c->maxh == c->minh);
 	settitle(c);
-
-	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 + c->w < 0) || (c->x >= sw))
-			c->x = (sw / 2) - (c->w / 2);
-		if((c->y + c->h < 0) || (c->y >= sh))
-			c->y = ((sh - bh) / 2) - (c->h / 2) + bh;
-	}
-	else {
-		c->x = (sw / 2) - (c->w / 2);
-		c->y = ((sh - bh) / 2) - (c->h / 2) + bh;
-	}
-
 	if(isvisible(c))
 		sel = c;
 	arrange(NULL);
@@ -301,10 +293,6 @@ resize(Client *c, Bool sizehints, Corner sticky)
 		if(c->maxh && c->h > c->maxh)
 			c->h = c->maxh;
 	}
-	if(c->x > sw) /* might happen on restart */
-		c->x = sw - c->w;
-	if(c->y > sh)
-		c->y = bottom - c->h;
 	if(sticky == TopRight || sticky == BotRight)
 		c->x = right - c->w;
 	if(sticky == BotLeft || sticky == BotRight)