2016-12-29 00:10:38 -08:00
|
|
|
local logger = require("logger")
|
2014-11-14 16:33:52 +01:00
|
|
|
local dump = require("dump")
|
2014-05-26 23:38:51 +08:00
|
|
|
local isAndroid, android = pcall(require, "android")
|
2013-03-13 01:18:53 +08:00
|
|
|
|
2013-10-18 22:38:07 +02:00
|
|
|
local Dbg = {
|
2016-10-25 00:08:47 -07:00
|
|
|
-- set to nil so first debug:turnOff call won't be skipped
|
2016-03-28 23:37:15 -07:00
|
|
|
is_on = nil,
|
2016-08-12 14:05:18 +08:00
|
|
|
is_verbose = nil,
|
2014-03-13 21:52:43 +08:00
|
|
|
ev_log = nil,
|
2013-03-13 01:18:53 +08:00
|
|
|
}
|
|
|
|
|
|
2013-10-18 22:38:07 +02:00
|
|
|
local Dbg_mt = {}
|
|
|
|
|
|
|
|
|
|
local function LvDEBUG(lv, ...)
|
2014-03-13 21:52:43 +08:00
|
|
|
local line = ""
|
|
|
|
|
for i,v in ipairs({...}) do
|
|
|
|
|
if type(v) == "table" then
|
2014-11-14 16:33:52 +01:00
|
|
|
line = line .. " " .. dump(v, lv)
|
2014-03-13 21:52:43 +08:00
|
|
|
else
|
|
|
|
|
line = line .. " " .. tostring(v)
|
|
|
|
|
end
|
|
|
|
|
end
|
2014-05-26 23:38:51 +08:00
|
|
|
if isAndroid then
|
|
|
|
|
android.LOGI("#"..line)
|
|
|
|
|
else
|
2016-07-24 16:47:10 -07:00
|
|
|
io.stdout:write(string.format("# %s %s\n", os.date("%x-%X"), line))
|
2014-10-18 15:31:05 +02:00
|
|
|
io.stdout:flush()
|
2014-05-26 23:38:51 +08:00
|
|
|
end
|
2013-10-18 22:38:07 +02:00
|
|
|
end
|
|
|
|
|
|
2013-03-13 01:18:53 +08:00
|
|
|
function Dbg:turnOn()
|
2016-03-28 23:37:15 -07:00
|
|
|
if self.is_on == true then return end
|
2014-03-13 21:52:43 +08:00
|
|
|
self.is_on = true
|
2016-12-29 00:10:38 -08:00
|
|
|
logger:setLevel(logger.levels.dbg)
|
2013-03-13 01:18:53 +08:00
|
|
|
|
2016-03-28 23:37:15 -07:00
|
|
|
Dbg_mt.__call = function(dbg, ...) LvDEBUG(math.huge, ...) end
|
2016-06-04 19:51:47 -07:00
|
|
|
Dbg.guard = function(_, mod, method, pre_guard, post_guard)
|
|
|
|
|
local old_method = mod[method]
|
|
|
|
|
mod[method] = function(...)
|
2016-03-28 23:37:15 -07:00
|
|
|
if pre_guard then
|
|
|
|
|
pre_guard(...)
|
|
|
|
|
end
|
|
|
|
|
local values = {old_method(...)}
|
|
|
|
|
if post_guard then
|
|
|
|
|
post_guard(...)
|
|
|
|
|
end
|
|
|
|
|
return unpack(values)
|
|
|
|
|
end
|
|
|
|
|
end
|
2017-06-23 10:04:11 -07:00
|
|
|
Dbg.dassert = function(check, msg)
|
|
|
|
|
assert(check, msg)
|
|
|
|
|
return check
|
|
|
|
|
end
|
2016-03-28 23:37:15 -07:00
|
|
|
|
2017-02-20 00:51:54 -08:00
|
|
|
-- TODO: close ev.log fd for children
|
2014-03-13 21:52:43 +08:00
|
|
|
-- create or clear ev log file
|
2014-05-28 12:57:53 +08:00
|
|
|
self.ev_log = io.open("ev.log", "w")
|
2013-03-13 01:18:53 +08:00
|
|
|
end
|
|
|
|
|
|
2016-03-28 23:37:15 -07:00
|
|
|
function Dbg:turnOff()
|
|
|
|
|
if self.is_on == false then return end
|
|
|
|
|
self.is_on = false
|
2016-12-29 00:10:38 -08:00
|
|
|
logger:setLevel(logger.levels.info)
|
2016-03-28 23:37:15 -07:00
|
|
|
function Dbg_mt.__call() end
|
|
|
|
|
function Dbg.guard() end
|
2017-06-23 10:04:11 -07:00
|
|
|
Dbg.dassert = function(check)
|
|
|
|
|
return check
|
|
|
|
|
end
|
2016-03-28 23:37:15 -07:00
|
|
|
if self.ev_log then
|
|
|
|
|
io.close(self.ev_log)
|
|
|
|
|
self.ev_log = nil
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2016-08-12 14:05:18 +08:00
|
|
|
function Dbg:setVerbose(verbose)
|
|
|
|
|
self.is_verbose = verbose
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
function Dbg:v(...)
|
|
|
|
|
if self.is_verbose then
|
|
|
|
|
LvDEBUG(math.huge, ...)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2013-03-13 01:18:53 +08:00
|
|
|
function Dbg:logEv(ev)
|
2018-04-03 14:56:28 +02:00
|
|
|
local ev_value = tostring(ev.value)
|
2014-03-13 21:52:43 +08:00
|
|
|
local log = ev.type.."|"..ev.code.."|"
|
2018-04-03 14:56:28 +02:00
|
|
|
..ev_value.."|"..ev.time.sec.."|"..ev.time.usec.."\n"
|
2015-10-03 14:18:47 +08:00
|
|
|
if self.ev_log then
|
|
|
|
|
self.ev_log:write(log)
|
|
|
|
|
self.ev_log:flush()
|
|
|
|
|
end
|
2013-03-13 01:18:53 +08:00
|
|
|
end
|
|
|
|
|
|
2013-10-25 20:07:58 +08:00
|
|
|
function Dbg:traceback()
|
2014-03-13 21:52:43 +08:00
|
|
|
LvDEBUG(math.huge, debug.traceback())
|
2013-10-25 20:07:58 +08:00
|
|
|
end
|
|
|
|
|
|
2013-10-18 22:38:07 +02:00
|
|
|
setmetatable(Dbg, Dbg_mt)
|
2013-03-15 05:01:34 -04:00
|
|
|
|
2016-03-28 23:37:15 -07:00
|
|
|
Dbg:turnOff()
|
2013-10-18 22:38:07 +02:00
|
|
|
return Dbg
|