diff options
author | Matthew Wild <mwild1@gmail.com> | 2016-01-02 20:42:53 +0000 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2016-01-02 20:42:53 +0000 |
commit | 8525a177737252f17ef63a09047b9bbac7f61282 (patch) | |
tree | cb3e8bce329accde5bcfa6c8138f4868a7aa9c58 /util/events.lua | |
parent | 93408770ef53ce0056d7a875f79b053f218eb806 (diff) | |
parent | 1eb8d252ea82a641caaf4996d1a9c31f62db83a2 (diff) | |
download | prosody-8525a177737252f17ef63a09047b9bbac7f61282.tar.gz prosody-8525a177737252f17ef63a09047b9bbac7f61282.zip |
Merge 0.10->trunk
Diffstat (limited to 'util/events.lua')
-rw-r--r-- | util/events.lua | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/util/events.lua b/util/events.lua index 825ffb19..073d2a60 100644 --- a/util/events.lua +++ b/util/events.lua @@ -17,10 +17,15 @@ local next = next; local _ENV = nil; local function new() + -- Map event name to ordered list of handlers (lazily built): handlers[event_name] = array_of_handler_functions local handlers = {}; + -- Array of wrapper functions that wrap all events (nil if empty) local global_wrappers; + -- Per-event wrappers: wrappers[event_name] = wrapper_function local wrappers = {}; + -- Event map: event_map[handler_function] = priority_number local event_map = {}; + -- Called on-demand to build handlers entries local function _rebuild_index(handlers, event) local _handlers = event_map[event]; if not _handlers or next(_handlers) == nil then return; end |