client: change border handling slightly + remove some old cruft

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Maarten Maathuis 2009-02-08 13:48:16 +01:00 committed by Julien Danjou
parent 62b2273b53
commit 0626d42396
2 changed files with 14 additions and 9 deletions

View File

@ -475,8 +475,9 @@ client_manage(xcb_window_t w, xcb_get_geometry_reply_t *wgeom, int phys_screen,
c->win = w; c->win = w;
c->geometry.x = wgeom->x; c->geometry.x = wgeom->x;
c->geometry.y = wgeom->y; c->geometry.y = wgeom->y;
c->geometry.width = wgeom->width + 2 * wgeom->border_width; /* Border will be added later. */
c->geometry.height = wgeom->height + 2 * wgeom->border_width; c->geometry.width = wgeom->width;
c->geometry.height = wgeom->height;
/* Also set internal geometry (client_ban() needs it). */ /* Also set internal geometry (client_ban() needs it). */
c->geometries.internal.x = wgeom->x; c->geometries.internal.x = wgeom->x;
c->geometries.internal.y = wgeom->y; c->geometries.internal.y = wgeom->y;
@ -1176,13 +1177,17 @@ client_setborder(client_t *c, int width)
if(width == c->border || width < 0) if(width == c->border || width < 0)
return; return;
/* Update geometry with the new border. */
c->geometry.width -= c->border;
c->geometry.height -= c->border;
c->border = width; c->border = width;
xcb_configure_window(globalconf.connection, c->win, xcb_configure_window(globalconf.connection, c->win,
XCB_CONFIG_WINDOW_BORDER_WIDTH, &w); XCB_CONFIG_WINDOW_BORDER_WIDTH, &w);
/* Maintain original size of client and also allow titlebar to be properly sized. */ c->geometry.width += c->border;
/* Don't forget that geometry is including border size. */ c->geometry.height += c->border;
client_resize(c, c->geometry, false); /* Tiled clients will be resized by the layout functions. */
client_need_arrange(c); client_need_arrange(c);
/* Changing border size also affects the size of the titlebar. */ /* Changing border size also affects the size of the titlebar. */

View File

@ -351,9 +351,9 @@ screen_client_moveto(client_t *c, int new_screen, bool dotag, bool doresize)
/* resize the client's original geometry if it doesn't fit the screen */ /* resize the client's original geometry if it doesn't fit the screen */
if (new_f_geometry.width > to.width) if (new_f_geometry.width > to.width)
new_f_geometry.width = to.width - 2 * c->border; new_f_geometry.width = to.width;
if (new_f_geometry.height > to.height) if (new_f_geometry.height > to.height)
new_f_geometry.height = to.height - 2 * c->border; new_f_geometry.height = to.height;
/* make sure the client is still on the screen */ /* make sure the client is still on the screen */
if (new_f_geometry.x + new_f_geometry.width > to.x + to.width) if (new_f_geometry.x + new_f_geometry.width > to.x + to.width)
@ -370,9 +370,9 @@ screen_client_moveto(client_t *c, int new_screen, bool dotag, bool doresize)
/* resize the client if it doesn't fit the new screen */ /* resize the client if it doesn't fit the new screen */
if(new_geometry.width > to.width) if(new_geometry.width > to.width)
new_geometry.width = to.width - 2 * c->border; new_geometry.width = to.width;
if(new_geometry.height > to.height) if(new_geometry.height > to.height)
new_geometry.height = to.height - 2 * c->border; new_geometry.height = to.height;
/* make sure the client is still on the screen */ /* make sure the client is still on the screen */
if(new_geometry.x + new_geometry.width > to.x + to.width) if(new_geometry.x + new_geometry.width > to.x + to.width)