LuaBridge Indescriptive errors



我使用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"]翻译为匹配的代码行?我能来一场堆叠比赛吗?

lua代码是";编译的";对文本代码执行string.dump,然后用luaL_loadbuffer加载它。加载并调用lua函数的Psuedo代码:

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);

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

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

我怀疑行号为0的原因是你告诉Lua通过设置"0"来删除行号;条";真实。

相关内容

  • 没有找到相关文章

最新更新