client: fix fixed size detection and resize blocking
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
36e4847dd1
commit
79468cf3a1
22
client.c
22
client.c
|
@ -537,7 +537,6 @@ client_resize(client_t *c, area_t geometry, bool hints)
|
||||||
int new_screen;
|
int new_screen;
|
||||||
area_t area;
|
area_t area;
|
||||||
layout_t *layout = layout_get_current(c->screen);
|
layout_t *layout = layout_get_current(c->screen);
|
||||||
bool fixed;
|
|
||||||
/* Values to configure a window is an array where values are
|
/* Values to configure a window is an array where values are
|
||||||
* stored according to 'value_mask' */
|
* stored according to 'value_mask' */
|
||||||
uint32_t values[5];
|
uint32_t values[5];
|
||||||
|
@ -555,8 +554,6 @@ client_resize(client_t *c, area_t geometry, bool hints)
|
||||||
area = display_area_get(c->phys_screen, NULL,
|
area = display_area_get(c->phys_screen, NULL,
|
||||||
&globalconf.screens[c->screen].padding);
|
&globalconf.screens[c->screen].padding);
|
||||||
|
|
||||||
fixed = client_isfixed(c);
|
|
||||||
|
|
||||||
if(geometry.x > area.width)
|
if(geometry.x > area.width)
|
||||||
geometry.x = area.width - geometry.width - 2 * c->border;
|
geometry.x = area.width - geometry.width - 2 * c->border;
|
||||||
if(geometry.y > area.height)
|
if(geometry.y > area.height)
|
||||||
|
@ -566,12 +563,10 @@ client_resize(client_t *c, area_t geometry, bool hints)
|
||||||
if(geometry.y + geometry.height + 2 * c->border < 0)
|
if(geometry.y + geometry.height + 2 * c->border < 0)
|
||||||
geometry.y = 0;
|
geometry.y = 0;
|
||||||
|
|
||||||
/* fixed windows can only change their x,y */
|
if(c->geometry.x != geometry.x
|
||||||
if((fixed && (c->geometry.x != geometry.x || c->geometry.y != geometry.y))
|
|
||||||
|| (!fixed && (c->geometry.x != geometry.x
|
|
||||||
|| c->geometry.y != geometry.y
|
|| c->geometry.y != geometry.y
|
||||||
|| c->geometry.width != geometry.width
|
|| c->geometry.width != geometry.width
|
||||||
|| c->geometry.height != geometry.height)))
|
|| c->geometry.height != geometry.height)
|
||||||
{
|
{
|
||||||
new_screen = screen_getbycoord(c->screen, geometry.x, geometry.y);
|
new_screen = screen_getbycoord(c->screen, geometry.x, geometry.y);
|
||||||
|
|
||||||
|
@ -1148,18 +1143,25 @@ luaA_client_geometry(lua_State *L)
|
||||||
client_t **c = luaA_checkudata(L, 1, "client");
|
client_t **c = luaA_checkudata(L, 1, "client");
|
||||||
|
|
||||||
if(lua_gettop(L) == 2)
|
if(lua_gettop(L) == 2)
|
||||||
{
|
if(client_isfloating(*c)
|
||||||
if((*c)->isfloating || layout_get_current((*c)->screen) == layout_floating)
|
|| layout_get_current((*c)->screen) == layout_floating)
|
||||||
{
|
{
|
||||||
area_t geometry;
|
area_t geometry;
|
||||||
|
|
||||||
luaA_checktable(L, 2);
|
luaA_checktable(L, 2);
|
||||||
geometry.x = luaA_getopt_number(L, 2, "x", (*c)->geometry.x);
|
geometry.x = luaA_getopt_number(L, 2, "x", (*c)->geometry.x);
|
||||||
geometry.y = luaA_getopt_number(L, 2, "y", (*c)->geometry.y);
|
geometry.y = luaA_getopt_number(L, 2, "y", (*c)->geometry.y);
|
||||||
|
if(client_isfixed(*c))
|
||||||
|
{
|
||||||
|
geometry.width = (*c)->geometry.width;
|
||||||
|
geometry.height = (*c)->geometry.height;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
geometry.width = luaA_getopt_number(L, 2, "width", (*c)->geometry.width);
|
geometry.width = luaA_getopt_number(L, 2, "width", (*c)->geometry.width);
|
||||||
geometry.height = luaA_getopt_number(L, 2, "height", (*c)->geometry.height);
|
geometry.height = luaA_getopt_number(L, 2, "height", (*c)->geometry.height);
|
||||||
client_resize(*c, geometry, false);
|
|
||||||
}
|
}
|
||||||
|
client_resize(*c, geometry, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
return luaA_pusharea(L, (*c)->geometry);
|
return luaA_pusharea(L, (*c)->geometry);
|
||||||
|
|
1
client.h
1
client.h
|
@ -93,7 +93,6 @@ client_isfixed(client_t *c)
|
||||||
{
|
{
|
||||||
return (c->maxw && c->minw && c->maxh && c->minh
|
return (c->maxw && c->minw && c->maxh && c->minh
|
||||||
&& c->maxw == c->minw && c->maxh == c->minh);
|
&& c->maxw == c->minw && c->maxh == c->minh);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Check if a client is floating.
|
/** Check if a client is floating.
|
||||||
|
|
4
mouse.c
4
mouse.c
|
@ -594,6 +594,10 @@ mouse_client_resize_floating(client_t *c, corner_t corner, bool infobox)
|
||||||
size_t cursor = CurResize;
|
size_t cursor = CurResize;
|
||||||
int top, bottom, left, right;
|
int top, bottom, left, right;
|
||||||
|
|
||||||
|
/* do not resize fixed client */
|
||||||
|
if(client_isfixed(c))
|
||||||
|
return;
|
||||||
|
|
||||||
screen = xutil_screen_get(globalconf.connection, c->phys_screen);
|
screen = xutil_screen_get(globalconf.connection, c->phys_screen);
|
||||||
|
|
||||||
/* get current mouse position */
|
/* get current mouse position */
|
||||||
|
|
Loading…
Reference in New Issue