# HG changeset patch # User Matthew Wild # Date 1599134443 -3600 # Node ID ad89e3cc67b63208bad0d226af4d997a503073b0 # Parent c99afee1c548e6b0da79e54ad390783491f0b7e2 util.helpers: when logging events, log individual handler calls diff -r c99afee1c548 -r ad89e3cc67b6 util/helpers.lua --- 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)