首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LuaBridge描述性错误

LuaBridge描述性错误
EN

Stack Overflow用户
提问于 2020-08-26 22:28:55
回答 1查看 41关注 0票数 0

我使用LuaJit和LuaBridge编译并执行lua代码。当lua代码抛出错误时,真的很难调试-我不知道它发生在哪一行,也不知道是什么导致了它。

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

代码语言:javascript
复制
"function foo(bar)\n"
        "   logger:info(bar.moo);" 

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

lua代码是通过对文本代码执行string.dump,然后用luaL_loadbuffer加载来“编译”的。加载和调用lua函数的Psuedo代码:

代码语言:javascript
复制
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);
EN

回答 1

Stack Overflow用户

发布于 2020-08-27 01:18:14

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

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

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63599864

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档