Skip to content

Latest commit

 

History

History
112 lines (53 loc) · 3.75 KB

feature-introduction.md

File metadata and controls

112 lines (53 loc) · 3.75 KB

项目介绍

[TOC]

LuaPanda 是一个基于VSCode扩展的lua调试器,设计目标是简单易用,支持多种开发框架。因当前项目大量使用lua进行开发,为了能够提升定位修复lua问题的效率,我们自己动手开发了这个工具。

LuaPanda 使用了lua + C 双架构。调试器主体使用lua开发(可独立运行),另外有一个高性能的C扩展库,兼顾了C的高效以及lua的灵活性。

lua适合的场景

  • 动态下发,避免游戏打包后无法调试的。适合发布后使用。

C 扩展适合的场景

  • 效率高,适合开发期调试。

调试器的IDE使用VSCode,下面是调试界面。

debugui

LuaPanda由两部分组成,分别是 Debugger Extension 和 debugger 调试器。架构可以参考下图 (图片引自 https://code.visualstudio.com/api/extension-guides/debugger-extension)

debug-arch2

Debugger Extension 是一个 VScode 扩展。Debugger是 Lua 实现的调试器。另外LuaPanda还提供一个可选的C调试库,运行时会自动引用,使用时不必关心。

特性

以下是支持的特性

  • 支持单步调试,断点调试,协程调试
  • 支持lua5.1- 5.3, 支持 win/mac 平台,支持 slua/xlua/slua-unreal 等框架
  • 在断点处可以监视和运行表达式,返回结果
  • 可以根据断点密集程度调整 hook 频率,有较好的效率
  • 支持 attach 模式,lua 运行过程中可随时建立连接
  • 使用 lua / C 双调试引擎。lua 部分可动态下发,避免打包后无法调试。C 部分效率高,适合开发期调试。

多平台的支持

Mac console + lua 5.1 debugon-console

Win slua-unreal + lua5.3 debugon-slua-ue

展示元表 和 upvalue

可以显示table的成员数目和元表,function的upvalue。 show-metatable

表达式监控 和 调试控制台

在变量监控区可以输入并监控表达式

REPL-watch

调试控制台,可以在断点处输入表达式

debug-console

在需要查看的变量或者是表达式前加p , 即可返回输出结果,如上图。

支持attach模式

通常的调试流程是先运行vscode端,再开始执行lua工程。 attach模式支持先执行lua工程,在希望调试的时候运行调试器,建立连接,开始调试。

attach_mode

条件断点和记录点

在 VSCode 行号前点击鼠标右键可选择普通断点,条件断点和记录点。

add_condition_bk

若用户输入的条件是 a == 2 , 调试器会执行表达式,并获取执行结果。注意执行结果 nil 和 false 为假,其他都为真。

记录点在被执行时会打印日志。日志输出在:DebugConsole - OUTPUT - Debugger/log

print_log

变量赋值

断点处允许用户修改变量的值, 用户也可以通过调试控制台给变量赋值。

企业微信截图_84fc8535-8733-4b04-9518-64cee91b2439

单文件调试

使用单文件调试,可以在工程中很方便的调试单个lua文件。

debug-file

详细配置请查看 单文件调试说明