44 lines
2.0 KiB
Markdown
44 lines
2.0 KiB
Markdown
# Lua Debugging TUI
|
|
|
|
This is a text-based user interface command line debugging utility for Lua and Moonscript.
|
|
It lets you browse the call stack, source code, and local variables right at the moment when
|
|
your code crashes (or when `ldt.breakpoint()` is called). Moonscript is fully supported, so the
|
|
callstack and source code panes will display the correct source for functions written in
|
|
Moonscript. It looks like this:
|
|
|
|

|
|
|
|
## Requirements
|
|
|
|
This library uses Curses via the [lcurses](https://github.com/rrthomas/lcurses) library
|
|
and [LPeg](http://www.inf.puc-rio.br/~roberto/lpeg).
|
|
|
|
## Usage
|
|
|
|
To catch all errors inside a block of code, use:
|
|
|
|
```Lua
|
|
local ldt = require("ldt")
|
|
ldt.guard(function()
|
|
-- Your crashing code here
|
|
end)
|
|
```
|
|
|
|
To trigger a breakpoint, just add a call to `ldt.breakpoint()`. Also, you can use `ldt.hijack()`
|
|
to replace `error()` and `assert()` with functions that will trigger the debugger. However,
|
|
this is not recommended for general purpose debugging because Lua errors like trying to index
|
|
a nil value do not call `error()`, so the debugger won't get triggered.
|
|
|
|
## Navigation
|
|
|
|
* Press 'q' to quit
|
|
* Arrow keys or h/j/k/l for movement within the active pane (yellow border); scroll wheel also works, but only for vertical scrolling. Shift+h/j/k/l moves 10 lines at a time.
|
|
* Press 'c' to select the call stack pane
|
|
* Press 's' to select the source code pane (showing the source code for the file of the function selected in the callstack pane)
|
|
* Press 'o' to open the selected file to the selected line in your system's default editor (`$EDITOR`)
|
|
* Press 'v' to select the variables pane (showing the variables at the selected level of the callstack)
|
|
* Press 'd' to select the data pane (showing the value of the selected variable)
|
|
* In the data pane, 'l'/right will expand table entries, and 'h'/left will collapse table entries.
|
|
* Press ':' or '>' to type in a command to be run in the current Lua context. The debugger will keep reading until a blank line is reached.
|
|
* Press '?' to type in an expression to be evaluated and printed.
|