libs/core: make memory tracer work with c and r events, avoid string allocations...
authorJo-Philipp Wich <jow@openwrt.org>
Fri, 10 Jul 2009 13:15:43 +0000 (13:15 +0000)
committerJo-Philipp Wich <jow@openwrt.org>
Fri, 10 Jul 2009 13:15:43 +0000 (13:15 +0000)
libs/core/luasrc/debug.lua

index f991ab8a60335a84af3decf707e7bc83d899d791..d64700e0e17179267f85046c8aabbadb80001734 100644 (file)
@@ -6,13 +6,20 @@ 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")
+function trap_memtrace(flags, dest)
+       flags = flags or "clr"
+       local tracefile = io.open(dest or "/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")
+               if tracefile then
+                       tracefile:write(
+                               "[", what, "] ", info.source, ":", (line or "?"), "\t",
+                               (info.namewhat or ""), "\t",
+                               (info.name or ""), "\t",
+                               collectgarbage("count"), "\n"
+                       )
+               end
        end
 
        debug.sethook(trap, flags)