Diff

util/helpers.lua @ 4681:3299223bbed5

util.helpers: Add show_events(), to show the events and handlers in a util.events object
author Matthew Wild <mwild1@gmail.com>
date Tue, 24 Apr 2012 18:54:34 +0100
parent 4536:285450536ec0
child 4705:447f5a94792d
line wrap: on
line diff
--- a/util/helpers.lua	Tue Apr 24 18:53:50 2012 +0100
+++ b/util/helpers.lua	Tue Apr 24 18:54:34 2012 +0100
@@ -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 @@
 	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