client: fix fixed size detection and resize blocking

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Julien Danjou 2008-11-10 12:10:06 +01:00
parent 36e4847dd1
commit 79468cf3a1
3 changed files with 20 additions and 15 deletions

View File

@ -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);

View File

@ -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.

View File

@ -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 */