我不知道如何有效地调试脚本。我需要像 Python 这样的堆栈输出,但默认情况下 Lua/C 没有这个。我不知道如何启用它。或者简单地说,如何从脚本中获取错误输出?
问问题
3297 次
2 回答
6
您可能正在寻找 xpcall 和 debug.traceback 的组合。您可以使用 xpcall 向其传递错误处理程序并使用 debug.traceback 获取堆栈跟踪:
function functionThatMayFail()
error('Failed')
end
local success, result = xpcall(functionThatMayFail,
function(err) return debug.traceback(err) end)
print(success, result)
此代码将打印:
false xpcall.lua:2: Failed
stack traceback:
xpcall.lua:6: in function <xpcall.lua:6>
[C]: in function 'error'
xpcall.lua:2: in function <xpcall.lua:1>
[C]: in function 'xpcall'
xpcall.lua:5: in main chunk
[C]: ?
于 2012-09-16T20:44:43.790 回答
0
Lua 解释器默认会产生错误输出。例如(我在这个脚本中引入了一个错字):
$ lua random.lua
lua: random.lua:6: attempt to call global 'xists' (a nil value)
stack traceback:
random.lua:6: in main chunk
[C]: ?
就错误输出而言,您能否澄清您正在尝试做的事情,或者更好的是您期望发生的事情没有发生?
于 2012-09-16T15:13:19.017 回答