1
0
Fork 0
mirror of https://github.com/bjc/prosody.git synced 2025-04-04 05:37:39 +03:00

tools/linedebug: Print each line of source executed

The extremely verbose debug output. Nice for getting some idea which
code runs most often, or where it pauses for no reason etc.
This commit is contained in:
Kim Alvefur 2020-10-28 23:05:15 +01:00
parent 43ec58831c
commit 4d9e30aff3

18
tools/linedebug.lua Normal file
View file

@ -0,0 +1,18 @@
local data = {}
local getinfo = debug.getinfo;
local function linehook(ev, li)
local S = getinfo(2, "S");
if S and S.source and S.source:match"^@" then
local file = S.source:sub(2);
local lines = data[file];
if not lines then
lines = {};
data[file] = lines;
for line in io.lines(file) do
lines[#lines+1] = line;
end
end
io.stderr:write(ev, " ", file, " ", li, " ", lines[li], "\n");
end
end
debug.sethook(linehook, "l");