From 5b1f8cd35c2b6ea88778238ef13b1e96ef5f32c1 Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Sun, 8 May 2016 15:00:14 +0200 Subject: [PATCH] Emit more signals when removing a screen's tags Signed-off-by: Uli Schlachter --- lib/awful/tag.lua | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/lib/awful/tag.lua b/lib/awful/tag.lua index 331b0deb..64e95d01 100644 --- a/lib/awful/tag.lua +++ b/lib/awful/tag.lua @@ -1352,6 +1352,7 @@ capi.tag.add_signal("property::urgent") capi.tag.add_signal("property::urgent_count") capi.tag.add_signal("property::volatile") +capi.tag.add_signal("request::screen") capi.tag.add_signal("removal-pending") capi.screen.add_signal("tag::history::update") @@ -1359,10 +1360,19 @@ capi.screen.add_signal("tag::history::update") capi.screen.connect_signal("tag::history::update", tag.history.update) capi.screen.connect_signal("removed", function(s) - -- First give other code a chance to clean up + -- First give other code a chance to move the tag to another screen + for _, t in pairs(s.tags) do + t:emit_signal("request::screen") + end + -- Everything that's left: Tell everyone that these tags go away (other code + -- could e.g. save clients) for _, t in pairs(s.tags) do t:emit_signal("removal-pending") end + -- Give other code yet another change to save clients + for _, c in pairs(capi.client.get(s)) do + c:emit_signal("request::tag", nil, { reason = "screen-removed" }) + end -- Then force all clients left to go somewhere random local fallback = nil for other_screen in capi.screen do