A debugger for Luau with debug adapter protocol(DAP) support.
└── luau_debugger
|
├── debugger # Debugger implementation, include a DAP server and
| # a debugger implemented with luau internal debug
| # api directly without hooking
|
├── luaud # A minimal Luau executable with debug support
├── extensions # VSCode extension for Luau debugger
└── tests # Test lua scripts
- Clone
cppdap
to local- Inside
cppdap
root, rungit submodule update --init
- Inside
- Clone
luau
to local - Build using CMake Presets with CLI or preset, for example with CLI:
cmake -DLUAU_ROOT=<luau path> -DCPP_DAP_ROOT=<cppdap path> -S . -B build
cmake --build
See features
See luaud for how to integrate with luau-debugger
in your project.
Tips:
- To avoid debug info to be stripped by luau compiler,
Luau::CompileOptions::debugLevel
should be set to2
- Call
Debugger::initialize(lua_State* L)
to initialize the debuggerDebugger::initialize(lua_State* L)
can be called multiple times to debug multiple lua statesDebugger::release(lua_State* L)
can be called to release the lua state before callinglua_close
- Call
Debugger::onLuaFileLoaded(lua_State* L, std::string_view path, bool is_entry)
when lua file entry is loaded and lua files are required - Call
Debugger::listen()
to start the DAP server - Call
Debugger::onError(std::string_view msg, lua_State* L)
if you want to redirect Lua error messages to the debug console.
To display userdata
variables in the debugger:
- Implement the
__iter
metamethod foruserdata
as described here. - Alternatively, implement a
__getters
metamethod that returns a table where the keys are property names and the values are functions that return the property values.