发生 SWIG_RuntimeError 的行号。
2013-2-3 0:51:36
收藏:0
阅读:164
评论:1
我正在通过swig运行带有C++库的Lua。当发生swig运行时错误时,我想知道引起问题的行。我收到的错误消息没有此信息。
如何找到触发错误的Lua代码的行?
例如,假设我有一个swig函数“swigstringcount”,它接受一个字符串:
local n=4
local m=swigstringcount(n)
print (m,n)
这个(显然错误的)代码在第二行产生错误。目前我所有得到的信息是:
error:SWIG_RuntimeError: swigstringcount requires a string
我希望它告诉我第2行产生了错误,就像普通的Lua错误消息一样。
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
基于这个 获取 Lua C API 调试信息的方法,我编写了一个 (有点乱) 的示例来展示如何将其集成到 SWIG 接口中:
%module test %{ #undef SWIG_fail_arg #define SWIG_fail_arg(func_name,argnum,type) \ {lua_Debug ar;\ lua_getstack(L, 1, &ar);\ lua_getinfo(L, "nSl", &ar);\ lua_pushfstring(L,"Error (%s:%d) in %s (arg %d), expected '%s' got '%s'",\ ar.source,ar.currentline,func_name,argnum,type,SWIG_Lua_typename(L,argnum));\ goto fail;} %} %include <std_string.i> %inline %{ void func(const std::string& str) {} %}这基本上将默认的
SWIG_fail_arg宏替换为一个修改后的宏,它获取并打印一些调试信息。我使用最新的 SWIG 版本测试过 (我认为你可能正在使用旧版本,因为我看到的文本不太匹配),但我能够做到:
Lua 5.1.4 Copyright (C) 1994-2008 Lua.org, PUC-Rio > require('test') > local n=4 > test.func(n) Error (=stdin:1) in func (arg 1), expected 'std::string const &' got 'nil' stack traceback: [C]: in function 'func' stdin:1: in main chunk [C]: ?不过,我似乎已经有了更多的调试信息(比如完整的堆栈跟踪)。