LuaBridge 的描述不清错误

我使用 LuaJit 和 LuaBridge 编译 lua 代码并执行它。 当 lua 代码引发错误时,很难进行调试 - 我不知道它发生在什么行或者什么引起它。

这是一个例子: [string "1"]:0: bad argument #1 to 'info' (string expected, got table) 在代码中:

"function foo(bar)\n"
        "   logger:info(bar.moo);"

如何将[string"1"]翻译成匹配的代码行? 我能得到一个堆栈跟踪吗?

使用 string.dump 将 lua 代码进行“编译”,然后使用 luaL_loadbuffer 进行加载。 加载和调用 lua 函数的伪代码:

int result = luaL_loadstring(L, script.c_str());
auto script_function = luabridge::LuaRef::fromStack(L);
auto string_module = luabridge::getGlobal(L, "string");
auto string_dump = string_module["dump"];
auto code = luabridge::LuaRef_cast<std::string>(string_dump(script_function, strip));
luaL_loadbuffer(L, code.data(), code.size(), std::to_string(current_id++).c_str());
lua_pcall(L, 0, LUA_MULTRET, -1);

auto func_to_call = luabridge::getGlobal(L, "foo");
func_to_call(&bar);
点赞
用户106104
用户106104

[string "1"] 来自你在此处提供的代码块名称: std::to_string(current_id++).c_str()

由于它不是以 @ 开头,因此被视为已加载的字符串,因此使用 [string ""] 语法。 如果您希望错误消息将其视为文件名,请在文件名前面添加 @。

而且我怀疑行号为0的原因是您告诉Lua删除了行号,通过将 "strip" 设置为true。

2020-08-26 17:18:13