Merge pull request #1013 from psychon/screen_area_signals

Screen area signals
This commit is contained in:
Emmanuel Lepage Vallée 2016-07-27 21:34:53 -04:00 committed by GitHub
commit e472339011
2 changed files with 27 additions and 3 deletions

View File

@ -277,6 +277,20 @@ end
capi.client.connect_signal("request::geometry", layout.move_handler) capi.client.connect_signal("request::geometry", layout.move_handler)
-- When a screen is moved, make (floating) clients follow it
capi.screen.connect_signal("property::geometry", function(s, old_geom)
local geom = s.geometry
local xshift = geom.x - old_geom.x
local yshift = geom.y - old_geom.y
for _, c in ipairs(capi.client.get(s)) do
local cgeom = c:geometry()
c:geometry({
x = cgeom.x + xshift,
y = cgeom.y + yshift
})
end
end)
return layout return layout
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80 -- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80

View File

@ -89,6 +89,10 @@
/** /**
* The screen coordinates. * The screen coordinates.
* *
* **Signal:**
*
* * *property::geometry*
*
* **Immutable:** true * **Immutable:** true
* @property geometry * @property geometry
* @param table * @param table
@ -550,9 +554,11 @@ screen_modified(screen_t *existing_screen, screen_t *other_screen)
lua_State *L = globalconf_get_lua_State(); lua_State *L = globalconf_get_lua_State();
if(!AREA_EQUAL(existing_screen->geometry, other_screen->geometry)) { if(!AREA_EQUAL(existing_screen->geometry, other_screen->geometry)) {
area_t old_geometry = existing_screen->geometry;
existing_screen->geometry = other_screen->geometry; existing_screen->geometry = other_screen->geometry;
luaA_object_push(L, existing_screen); luaA_object_push(L, existing_screen);
luaA_object_emit_signal(L, -1, "property::geometry", 0); luaA_pusharea(L, old_geometry);
luaA_object_emit_signal(L, -2, "property::geometry", 1);
lua_pop(L, 1); lua_pop(L, 1);
screen_update_workarea(existing_screen); screen_update_workarea(existing_screen);
} }
@ -775,10 +781,12 @@ void screen_update_workarea(screen_t *screen)
if (AREA_EQUAL(area, screen->workarea)) if (AREA_EQUAL(area, screen->workarea))
return; return;
area_t old_workarea = screen->workarea;
screen->workarea = area; screen->workarea = area;
lua_State *L = globalconf_get_lua_State(); lua_State *L = globalconf_get_lua_State();
luaA_object_push(L, screen); luaA_object_push(L, screen);
luaA_object_emit_signal(L, -1, "property::workarea", 0); luaA_pusharea(L, old_workarea);
luaA_object_emit_signal(L, -2, "property::workarea", 1);
lua_pop(L, 1); lua_pop(L, 1);
} }
@ -1099,6 +1107,7 @@ luaA_screen_fake_resize(lua_State *L)
int y = luaL_checkinteger(L, 3); int y = luaL_checkinteger(L, 3);
int width = luaL_checkinteger(L, 4); int width = luaL_checkinteger(L, 4);
int height = luaL_checkinteger(L, 5); int height = luaL_checkinteger(L, 5);
area_t old_geometry = screen->geometry;
screen->geometry.x = x; screen->geometry.x = x;
screen->geometry.y = y; screen->geometry.y = y;
@ -1107,7 +1116,8 @@ luaA_screen_fake_resize(lua_State *L)
screen_update_workarea(screen); screen_update_workarea(screen);
luaA_object_emit_signal(L, 1, "property::geometry", 0); luaA_pusharea(L, old_geometry);
luaA_object_emit_signal(L, 1, "property::geometry", 1);
return 0; return 0;
} }