From 080609f6ec7c451c9fa34fdf1d1657f1993bf3f4 Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Sat, 16 Apr 2016 14:49:09 +0200 Subject: [PATCH] Add a screen checker. A client cannot be used any more after it was unmanaged. Similarly, Lua shouldn't be allowed to e.g. assign a client to a screen that was removed. This commit adds such a checker which "breaks" all screens which are not in the global screen list. Signed-off-by: Uli Schlachter --- objects/screen.c | 12 +++++++++++- objects/screen.h | 2 ++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/objects/screen.c b/objects/screen.c index 5b07b948..1efa1c6a 100644 --- a/objects/screen.c +++ b/objects/screen.c @@ -183,6 +183,13 @@ screen_wipe(screen_t *s) screen_output_array_wipe(&s->outputs); } +/** Check if a screen is valid */ +static bool +screen_checker(screen_t *s) +{ + return s->valid; +} + /** Get a screen argument from the lua stack */ screen_t * luaA_checkscreen(lua_State *L, int sidx) @@ -455,6 +462,7 @@ screen_scan(void) assert(globalconf.screens.len > 0); foreach(screen, globalconf.screens) { + (*screen)->valid = true; luaA_object_push(L, *screen); luaA_object_emit_signal(L, -1, "added", 0); lua_pop(L, 1); @@ -486,6 +494,7 @@ screen_refresh(void) found |= (*new_screen)->xid == (*old_screen)->xid; if(!found) { screen_array_append(&globalconf.screens, *new_screen); + (*new_screen)->valid = true; luaA_object_push(L, *new_screen); luaA_object_emit_signal(L, -1, "added", 0); /* Get an extra reference since both new_screens and @@ -506,6 +515,7 @@ screen_refresh(void) lua_pop(L, 1); screen_array_take(&globalconf.screens, i); luaA_object_unref(L, old_screen); + old_screen->valid = false; i--; } @@ -933,7 +943,7 @@ screen_class_setup(lua_State *L) luaA_class_setup(L, &screen_class, "screen", NULL, (lua_class_allocator_t) screen_new, (lua_class_collector_t) screen_wipe, - NULL, + (lua_class_checker_t) screen_checker, luaA_class_index_miss_property, luaA_class_newindex_miss_property, screen_methods, screen_meta); luaA_class_add_property(&screen_class, "geometry", diff --git a/objects/screen.h b/objects/screen.h index 949e4615..bba8810f 100644 --- a/objects/screen.h +++ b/objects/screen.h @@ -33,6 +33,8 @@ ARRAY_TYPE(screen_output_t, screen_output) struct a_screen { LUA_OBJECT_HEADER + /** Is this screen still valid and may be used? */ + bool valid; /** Screen geometry */ area_t geometry; /** The screen outputs informations */