util.helpers: Add show_events(), to show the events and handlers in a util.events...
authorMatthew Wild <mwild1@gmail.com>
Tue, 24 Apr 2012 17:54:34 +0000 (18:54 +0100)
committerMatthew Wild <mwild1@gmail.com>
Tue, 24 Apr 2012 17:54:34 +0000 (18:54 +0100)
util/helpers.lua

index a8c8c61283c389e4d75ab6d9807e51df61f643a9..ad23dd79572295c5bc7c727b65f489fc09c9a278 100644 (file)
@@ -6,6 +6,8 @@
 -- COPYING file in the source package for more information.
 --
 
+local debug = require "util.debug";
+
 module("helpers", package.seeall);
 
 -- Helper functions for debugging
@@ -31,6 +33,33 @@ function revert_log_events(events)
        events.fire_event, events[events.fire_event] = events[events.fire_event], nil; -- :))
 end
 
+function show_events(events)
+       local event_handlers = events._handlers;
+       local events_array = {};
+       local event_handler_arrays = {};
+       for event in pairs(events._event_map) do
+               local handlers = event_handlers[event];
+               table.insert(events_array, event);
+               local handler_strings = {};
+               for i, handler in ipairs(handlers) do
+                       local upvals = debug.string_from_var_table(debug.get_upvalues_table(handler));
+                       handler_strings[i] = "  "..i..": "..tostring(handler)..(upvals and ("\n        "..upvals) or "");
+               end
+               event_handler_arrays[event] = handler_strings;
+       end
+       table.sort(events_array);
+       local i = 1;
+       repeat
+               local handlers = event_handler_arrays[events_array[i]];
+               for j=#handlers, 1, -1 do
+                       table.insert(events_array, i+1, handlers[j]);
+               end
+               if i > 1 then events_array[i] = "\n"..events_array[i]; end
+               i = i + #handlers + 1
+       until i == #events_array;
+       return table.concat(events_array, "\n");
+end
+
 function get_upvalue(f, get_name)
        local i, name, value = 0;
        repeat