summaryrefslogtreecommitdiffhomepage
path: root/libs/core/luasrc/debug.lua
blob: f991ab8a60335a84af3decf707e7bc83d899d791 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
local debug = require "debug"
local io = require "io"
local collectgarbage = collectgarbage

module "luci.debug"
__file__ = debug.getinfo(1, 'S').source:sub(2)

-- Enables the memory tracer with given flags and returns a function to disable the tracer again
function trap_memtrace(flags)
	flags = flags or "l"
	local tracefile = io.open("/tmp/memtrace", "w")

	local function trap(what, line)
		local info = debug.getinfo(2, "Sn")
		tracefile:write(info.source..":"..line.."\t"..(info.namewhat or "").."\t"..(info.name or "").."\t"..collectgarbage("count").."\n")
	end

	debug.sethook(trap, flags)

	return function()
		debug.sethook()
		tracefile:close()
	end
end