aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarc2008-01-03 20:20:20 +0000
committermarc2008-01-03 20:20:20 +0000
commit12931679ea1845d2adf4c9171e175a334e4f2902 (patch)
tree413cfe754f620af3459fcb049a1cf4bce659ff2e
parent01e81487afb71345f5fad8c1dd61ccaa551a84be (diff)
downloadcwm-12931679ea1845d2adf4c9171e175a334e4f2902.tar.gz
Adjust initial window placement with any geometry that would place
the window at or over the right or bottom edge. OK oda@
Diffstat (limited to '')
-rw-r--r--client.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/client.c b/client.c
index 32948e2..386be5d 100644
--- a/client.c
+++ b/client.c
@@ -4,7 +4,7 @@
* Copyright (c) 2004 Marius Aamodt Eriksen <marius@monkey.org>
* All rights reserved.
*
- * $Id: client.c,v 1.8 2008/01/01 22:28:59 marc Exp $
+ * $Id: client.c,v 1.9 2008/01/03 20:20:20 marc Exp $
*/
#include "headers.h"
@@ -91,7 +91,6 @@ client_new(Window win, struct screen_ctx *sc, int mapped)
cc->geom.y = wattr.y;
cc->geom.width = wattr.width;
cc->geom.height = wattr.height;
- cc->geom.height = wattr.height;
cc->cmap = wattr.colormap;
if (wattr.map_state != IsViewable) {
@@ -808,12 +807,16 @@ client_placecalc(struct client_ctx *cc)
if (cc->size->flags & USPosition) {
if (cc->size->x > 0)
x = cc->size->x;
- if (x <= 0 || x >= xmax)
+ if (x < cc->bwidth)
x = cc->bwidth;
+ else if (x > xslack)
+ x = xslack;
if (cc->size->y > 0)
y = cc->size->y;
- if (y <= 0 || y >= ymax)
+ if (y < cc->bwidth)
y = cc->bwidth;
+ else if (y > yslack)
+ y = yslack;
} else {
if (yslack < 0) {
y = cc->bwidth;