Merge pull request #1013 from psychon/screen_area_signals
Screen area signals
This commit is contained in:
commit
e472339011
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue