event: do not store resize events of banned clients
This should fix the problem seen with Firefox. When clicking on a file that will launch a "Save as" dialog, and switching tag quickly, the client is banned and move off of the viewport. Then FF send a ConfigureRequest to re-move it to this negative coordinates, which we did handle and set as its geometries. Now we just honor the (bad and useless) move but we do not use client_resize() Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
b878e1491f
commit
f45cdee4eb
102
event.c
102
event.c
|
@ -220,49 +220,9 @@ event_handle_button(void *data, xcb_connection_t *connection, xcb_button_press_e
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** The configure event handler.
|
static void
|
||||||
* \param data currently unused.
|
event_handle_configurerequest_configure_window(xcb_configure_request_event_t *ev)
|
||||||
* \param connection The connection to the X server.
|
|
||||||
* \param ev The event.
|
|
||||||
*/
|
|
||||||
static int
|
|
||||||
event_handle_configurerequest(void *data __attribute__ ((unused)),
|
|
||||||
xcb_connection_t *connection, xcb_configure_request_event_t *ev)
|
|
||||||
{
|
{
|
||||||
client_t *c;
|
|
||||||
area_t geometry;
|
|
||||||
|
|
||||||
if((c = client_getbywin(ev->window)))
|
|
||||||
{
|
|
||||||
geometry = c->geometry;
|
|
||||||
|
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_X)
|
|
||||||
geometry.x = ev->x;
|
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_Y)
|
|
||||||
geometry.y = ev->y;
|
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_WIDTH)
|
|
||||||
geometry.width = ev->width;
|
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_HEIGHT)
|
|
||||||
geometry.height = ev->height;
|
|
||||||
|
|
||||||
/** Configure request are sent with size relative to real (internal)
|
|
||||||
* window size, i.e. without titlebars and borders. */
|
|
||||||
geometry = titlebar_geometry_add(c->titlebar, c->border, geometry);
|
|
||||||
|
|
||||||
if(geometry.x != c->geometry.x || geometry.y != c->geometry.y
|
|
||||||
|| geometry.width != c->geometry.width || geometry.height != c->geometry.height)
|
|
||||||
{
|
|
||||||
client_resize(c, geometry, false);
|
|
||||||
/* All the wiboxes (may) need to be repositioned. */
|
|
||||||
if(client_hasstrut(c))
|
|
||||||
wibox_update_positions();
|
|
||||||
client_need_arrange(c);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
window_configure(c->win, geometry, c->border);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
uint16_t config_win_mask = 0;
|
uint16_t config_win_mask = 0;
|
||||||
uint32_t config_win_vals[7];
|
uint32_t config_win_vals[7];
|
||||||
unsigned short i = 0;
|
unsigned short i = 0;
|
||||||
|
@ -303,8 +263,64 @@ event_handle_configurerequest(void *data __attribute__ ((unused)),
|
||||||
config_win_vals[i++] = ev->stack_mode;
|
config_win_vals[i++] = ev->stack_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
xcb_configure_window(connection, ev->window, config_win_mask, config_win_vals);
|
xcb_configure_window(globalconf.connection, ev->window, config_win_mask, config_win_vals);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** The configure event handler.
|
||||||
|
* \param data currently unused.
|
||||||
|
* \param connection The connection to the X server.
|
||||||
|
* \param ev The event.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
event_handle_configurerequest(void *data __attribute__ ((unused)),
|
||||||
|
xcb_connection_t *connection, xcb_configure_request_event_t *ev)
|
||||||
|
{
|
||||||
|
client_t *c;
|
||||||
|
area_t geometry;
|
||||||
|
|
||||||
|
if((c = client_getbywin(ev->window)))
|
||||||
|
{
|
||||||
|
geometry = c->geometry;
|
||||||
|
|
||||||
|
if(ev->value_mask & XCB_CONFIG_WINDOW_X)
|
||||||
|
geometry.x = ev->x;
|
||||||
|
if(ev->value_mask & XCB_CONFIG_WINDOW_Y)
|
||||||
|
geometry.y = ev->y;
|
||||||
|
if(ev->value_mask & XCB_CONFIG_WINDOW_WIDTH)
|
||||||
|
geometry.width = ev->width;
|
||||||
|
if(ev->value_mask & XCB_CONFIG_WINDOW_HEIGHT)
|
||||||
|
geometry.height = ev->height;
|
||||||
|
|
||||||
|
/** Configure request are sent with size relative to real (internal)
|
||||||
|
* window size, i.e. without titlebars and borders. */
|
||||||
|
geometry = titlebar_geometry_add(c->titlebar, c->border, geometry);
|
||||||
|
|
||||||
|
if(geometry.x != c->geometry.x
|
||||||
|
|| 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. */
|
||||||
|
if(client_hasstrut(c))
|
||||||
|
wibox_update_positions();
|
||||||
|
client_need_arrange(c);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
window_configure(c->win, geometry, c->border);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
event_handle_configurerequest_configure_window(ev);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue