event: fix configurerequest

- We have to be careful with geometry around protocol code.

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Maarten Maathuis 2009-02-08 13:48:17 +01:00 committed by Julien Danjou
parent 0626d42396
commit bd6e568083
3 changed files with 17 additions and 20 deletions

View File

@ -659,8 +659,9 @@ client_geometry_hints(client_t *c, area_t geometry)
* \param c Client to resize. * \param c Client to resize.
* \param geometry New window geometry. * \param geometry New window geometry.
* \param hints Use size hints. * \param hints Use size hints.
* \return true if an actual resize occurred.
*/ */
void bool
client_resize(client_t *c, area_t geometry, bool hints) client_resize(client_t *c, area_t geometry, bool hints)
{ {
int new_screen; int new_screen;
@ -687,7 +688,7 @@ client_resize(client_t *c, area_t geometry, bool hints)
geometry_internal = client_geometry_hints(c, geometry_internal); geometry_internal = client_geometry_hints(c, geometry_internal);
if(geometry_internal.width == 0 || geometry_internal.height == 0) if(geometry_internal.width == 0 || geometry_internal.height == 0)
return; return false;
/* Also let client hints propegate to the "official" geometry. */ /* Also let client hints propegate to the "official" geometry. */
geometry = titlebar_geometry_add(c->titlebar, c->border, geometry_internal); geometry = titlebar_geometry_add(c->titlebar, c->border, geometry_internal);
@ -732,7 +733,11 @@ client_resize(client_t *c, area_t geometry, bool hints)
/* execute hook */ /* execute hook */
hooks_property(c, "geometry"); hooks_property(c, "geometry");
return true;
} }
return false;
} }
/** Set a client minimized, or not. /** Set a client minimized, or not.

View File

@ -52,7 +52,7 @@ void client_ban(client_t *);
void client_unban(client_t *); void client_unban(client_t *);
void client_manage(xcb_window_t, xcb_get_geometry_reply_t *, int, bool); void client_manage(xcb_window_t, xcb_get_geometry_reply_t *, int, bool);
area_t client_geometry_hints(client_t *, area_t); area_t client_geometry_hints(client_t *, area_t);
void client_resize(client_t *, area_t, bool); bool client_resize(client_t *, area_t, bool);
void client_unmanage(client_t *); void client_unmanage(client_t *);
void client_saveprops_tags(client_t *); void client_saveprops_tags(client_t *);
void client_kill(client_t *); void client_kill(client_t *);

24
event.c
View File

@ -297,38 +297,30 @@ event_handle_configurerequest(void *data __attribute__ ((unused)),
/* We do have to ensure the windows don't end up in the visible screen. */ /* We do have to ensure the windows don't end up in the visible screen. */
geometry.x = - (geometry.width + 2*c->border); geometry.x = - (geometry.width + 2*c->border);
geometry.y = - (geometry.height + 2*c->border); geometry.y = - (geometry.height + 2*c->border);
window_configure(c->win, geometry, c->border);
event_handle_configurerequest_configure_window(ev);
} }
else else
{ {
/** Configure request are sent with size relative to real (internal) /** Configure request are sent with size relative to real (internal)
* window size, i.e. without titlebars and borders. */ * window size, i.e. without titlebars and borders. */
geometry = titlebar_geometry_add(c->titlebar, c->border, geometry); geometry = titlebar_geometry_add(c->titlebar, c->border, geometry);
}
if(geometry.x != c->geometry.x if(client_resize(c, geometry, false))
|| geometry.y != c->geometry.y
|| geometry.width != c->geometry.width
|| geometry.height != c->geometry.height)
{ {
if(c->isbanned)
{
window_configure(c->win, geometry, c->border);
event_handle_configurerequest_configure_window(ev);
}
else
{
client_resize(c, geometry, false);
/* All the wiboxes (may) need to be repositioned. */ /* All the wiboxes (may) need to be repositioned. */
if(client_hasstrut(c)) if(client_hasstrut(c))
wibox_update_positions(); wibox_update_positions();
client_need_arrange(c); client_need_arrange(c);
return 0;
}
} }
else else
{
/* Resize wasn't officially needed, but we don't want to break expectations. */
geometry = titlebar_geometry_remove(c->titlebar, c->border, c->geometry);
window_configure(c->win, geometry, c->border); window_configure(c->win, geometry, c->border);
} }
}
}
else else
event_handle_configurerequest_configure_window(ev); event_handle_configurerequest_configure_window(ev);