The new package luci-base-libs provides the modules that not strictly relate to the web-interface of luci. By separating these libs they can be used by other packages without having to install the web-components. This change was inspired by providing a shell-only interface for 4MB-flash devices, by keeping as much code common with a full install. Signed-off-by: Sven Roederer <freifunk@it-solutions.geroedel.de>
37 lines
874 B
Lua
37 lines
874 B
Lua
local debug = require "debug"
|
|
local io = require "io"
|
|
local collectgarbage, floor = collectgarbage, math.floor
|
|
|
|
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, dest)
|
|
flags = flags or "clr"
|
|
local tracefile = io.open(dest or "/tmp/memtrace", "w")
|
|
local peak = 0
|
|
|
|
local function trap(what, line)
|
|
local info = debug.getinfo(2, "Sn")
|
|
local size = floor(collectgarbage("count"))
|
|
if size > peak then
|
|
peak = size
|
|
end
|
|
if tracefile then
|
|
tracefile:write(
|
|
"[", what, "] ", info.source, ":", (line or "?"), "\t",
|
|
(info.namewhat or ""), "\t",
|
|
(info.name or ""), "\t",
|
|
size, " (", peak, ")\n"
|
|
)
|
|
end
|
|
end
|
|
|
|
debug.sethook(trap, flags)
|
|
|
|
return function()
|
|
debug.sethook()
|
|
tracefile:close()
|
|
end
|
|
end
|
|
|