[TOC]
LuaPanda 是一个基于VSCode扩展的lua调试器,设计目标是简单易用,支持多种开发框架。因当前项目大量使用lua进行开发,为了能够提升定位修复lua问题的效率,我们自己动手开发了这个工具。
LuaPanda 使用了lua + C 双架构。调试器主体使用lua开发(可独立运行),另外有一个高性能的C扩展库,兼顾了C的高效以及lua的灵活性。
lua适合的场景
- 动态下发,避免游戏打包后无法调试的。适合发布后使用。
C 扩展适合的场景
- 效率高,适合开发期调试。
调试器的IDE使用VSCode,下面是调试界面。
LuaPanda由两部分组成,分别是 Debugger Extension 和 debugger 调试器。架构可以参考下图 (图片引自 https://code.visualstudio.com/api/extension-guides/debugger-extension)
Debugger Extension 是一个 VScode 扩展。Debugger是 Lua 实现的调试器。另外LuaPanda还提供一个可选的C调试库,运行时会自动引用,使用时不必关心。
以下是支持的特性
- 支持单步调试,断点调试,协程调试
- 支持lua5.1- 5.3, 支持 win/mac 平台,支持 slua/xlua/slua-unreal 等框架
- 在断点处可以监视和运行表达式,返回结果
- 可以根据断点密集程度调整 hook 频率,有较好的效率
- 支持 attach 模式,lua 运行过程中可随时建立连接
- 使用 lua / C 双调试引擎。lua 部分可动态下发,避免打包后无法调试。C 部分效率高,适合开发期调试。
可以显示table的成员数目和元表,function的upvalue。
在变量监控区可以输入并监控表达式
调试控制台,可以在断点处输入表达式
在需要查看的变量或者是表达式前加p , 即可返回输出结果,如上图。
通常的调试流程是先运行vscode端,再开始执行lua工程。 attach模式支持先执行lua工程,在希望调试的时候运行调试器,建立连接,开始调试。
在 VSCode 行号前点击鼠标右键可选择普通断点,条件断点和记录点。
若用户输入的条件是 a == 2
, 调试器会执行表达式,并获取执行结果。注意执行结果 nil 和 false 为假,其他都为真。
记录点在被执行时会打印日志。日志输出在:DebugConsole - OUTPUT - Debugger/log
断点处允许用户修改变量的值, 用户也可以通过调试控制台给变量赋值。
使用单文件调试,可以在工程中很方便的调试单个lua文件。
详细配置请查看 单文件调试说明