c84347946e92aefb3b74414c7050148c2ca4e90f
[prosody.git] / util / helpers.lua
1
2 module("helpers", package.seeall);
3
4 -- Helper functions for debugging
5
6 local log = require "util.logger".init("util.debug");
7
8 function log_events(events, name, logger)
9         local f = events.fire_event;
10         if not f then
11                 error("Object does not appear to be a util.events object");
12         end
13         logger = logger or log;
14         name = name or tostring(events);
15         function events.fire_event(event, ...)
16                 logger("debug", "%s firing event: %s", name, event);
17                 return f(event, ...);
18         end
19         events[events.fire_event] = f;
20         return events;
21 end
22
23 function revert_log_events(events)
24         events.fire_event, events[events.fire_event] = events[events.fire_event], nil; -- :)
25 end
26
27 return _M;