mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +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:
parent
43ec58831c
commit
4d9e30aff3
1 changed files with 18 additions and 0 deletions
18
tools/linedebug.lua
Normal file
18
tools/linedebug.lua
Normal 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");
|
Loading…
Add table
Add a link
Reference in a new issue