Apply window gravity when a window moves itself
This just makes us do what ICCCM requires us to do. Tested via metacity's test-gravity.c. Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
parent
39df6d98e7
commit
367c3acbcd
19
event.c
19
event.c
|
@ -311,19 +311,30 @@ event_handle_configurerequest(xcb_configure_request_event_t *ev)
|
||||||
if((c = client_getbywin(ev->window)))
|
if((c = client_getbywin(ev->window)))
|
||||||
{
|
{
|
||||||
area_t geometry = c->geometry;
|
area_t geometry = c->geometry;
|
||||||
|
uint16_t bw = c->border_width;
|
||||||
|
uint16_t tb_left = c->titlebar[CLIENT_TITLEBAR_LEFT].size;
|
||||||
|
uint16_t tb_right = c->titlebar[CLIENT_TITLEBAR_RIGHT].size;
|
||||||
|
uint16_t tb_top = c->titlebar[CLIENT_TITLEBAR_TOP].size;
|
||||||
|
uint16_t tb_bottom = c->titlebar[CLIENT_TITLEBAR_BOTTOM].size;
|
||||||
|
uint16_t deco_left = bw + tb_left;
|
||||||
|
uint16_t deco_right = bw + tb_right;
|
||||||
|
uint16_t deco_top = bw + tb_top;
|
||||||
|
uint16_t deco_bottom = bw + tb_bottom;
|
||||||
int16_t diff_w = 0, diff_h = 0, diff_border = 0;
|
int16_t diff_w = 0, diff_h = 0, diff_border = 0;
|
||||||
|
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_X)
|
if(ev->value_mask & XCB_CONFIG_WINDOW_X)
|
||||||
{
|
{
|
||||||
|
int16_t diff = 0;
|
||||||
geometry.x = ev->x;
|
geometry.x = ev->x;
|
||||||
/* The ConfigureRequest specifies the position of the outer corner of the client window, we want the frame */
|
xwindow_translate_for_gravity(c->size_hints.win_gravity, deco_left, 0, deco_right, 0, &diff, NULL);
|
||||||
geometry.x -= c->border_width;
|
geometry.x += diff;
|
||||||
}
|
}
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_Y)
|
if(ev->value_mask & XCB_CONFIG_WINDOW_Y)
|
||||||
{
|
{
|
||||||
|
int16_t diff = 0;
|
||||||
geometry.y = ev->y;
|
geometry.y = ev->y;
|
||||||
/* The ConfigureRequest specifies the position of the outer corner of the client window, we want the frame */
|
xwindow_translate_for_gravity(c->size_hints.win_gravity, 0, deco_top, 0, deco_bottom, NULL, &diff);
|
||||||
geometry.y -= c->border_width;
|
geometry.y += diff;
|
||||||
}
|
}
|
||||||
if(ev->value_mask & XCB_CONFIG_WINDOW_WIDTH)
|
if(ev->value_mask & XCB_CONFIG_WINDOW_WIDTH)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue