Adjust initial window placement with any geometry that would place

the window at or over the right or bottom edge.
OK oda@
This commit is contained in:
marc 2008-01-03 20:20:20 +00:00
parent 847191cff3
commit 160d6aa910

View File

@ -91,7 +91,6 @@ client_new(Window win, struct screen_ctx *sc, int mapped)
cc->geom.y = wattr.y; cc->geom.y = wattr.y;
cc->geom.width = wattr.width; cc->geom.width = wattr.width;
cc->geom.height = wattr.height; cc->geom.height = wattr.height;
cc->geom.height = wattr.height;
cc->cmap = wattr.colormap; cc->cmap = wattr.colormap;
if (wattr.map_state != IsViewable) { if (wattr.map_state != IsViewable) {
@ -808,12 +807,16 @@ client_placecalc(struct client_ctx *cc)
if (cc->size->flags & USPosition) { if (cc->size->flags & USPosition) {
if (cc->size->x > 0) if (cc->size->x > 0)
x = cc->size->x; x = cc->size->x;
if (x <= 0 || x >= xmax) if (x < cc->bwidth)
x = cc->bwidth; x = cc->bwidth;
else if (x > xslack)
x = xslack;
if (cc->size->y > 0) if (cc->size->y > 0)
y = cc->size->y; y = cc->size->y;
if (y <= 0 || y >= ymax) if (y < cc->bwidth)
y = cc->bwidth; y = cc->bwidth;
else if (y > yslack)
y = yslack;
} else { } else {
if (yslack < 0) { if (yslack < 0) {
y = cc->bwidth; y = cc->bwidth;