Diff

util/helpers.lua @ 11059:ad89e3cc67b6

util.helpers: when logging events, log individual handler calls
author Matthew Wild <mwild1@gmail.com>
date Thu, 03 Sep 2020 13:00:43 +0100
parent 8411:a9e8523a5e73
child 12975:d10957394a3c
line wrap: on
line diff
--- a/util/helpers.lua	Thu Sep 03 12:59:43 2020 +0100
+++ b/util/helpers.lua	Thu Sep 03 13:00:43 2020 +0100
@@ -23,12 +23,27 @@
 		logger("debug", "%s firing event: %s", name, event);
 		return f(event, ...);
 	end
+
+	local function event_handler_hook(handler, event_name, event_data)
+		logger("debug", "calling handler for %s: %s", event_name, handler);
+		local ok, ret = pcall(handler, event_data);
+		if not ok then
+			logger("error", "error in event handler %s: %s", handler, ret);
+			error(ret);
+		end
+		if ret ~= nil then
+			logger("debug", "event chain ended for %s by %s with result: %s", event_name, handler, ret);
+		end
+		return ret;
+	end
+	events.set_debug_hook(event_handler_hook);
 	events[events.fire_event] = f;
 	return events;
 end
 
 local function revert_log_events(events)
 	events.fire_event, events[events.fire_event] = events[events.fire_event], nil; -- :))
+	events.set_debug_hook(nil);
 end
 
 local function log_host_events(host)