This document was created to still give a "easy" to understand explanation because the plugin's inner workings are probably hard to understand only by reading code.
This should give "something" to work with if you plan to
make modifications to the code, make your own debugger or
any other purpose involving osv
.
Terminology:
- debbugee (i.e. the process which will be debugged )
- debugger client (i.e. the process where the debugger is running)
DEBUGGEE
┌────────────────────┐
│ │
launch() │ ┌───────────┐ │ DAP SERVER
────────────────►│spawn nvim │────────────► ┌──────────────────┐
│ └─────┬─────┘ │ │ │
│ │ │ │ │
│ ▼ │ │ │
│┌──────────────────┐│ │ │
││serverstart() ││ │ │
││ ││ pass │ │
││generate server ├───────────►┌──────────────┐ │
││address ││ address │ │set address │ │
│└──────────────────┘│ │ │ in │ │
│ │ │ parent_conn_addr
│ │ │ │ │ │ │
│ │ │ │ │ │ │
│ │ │ │ └──────────────┘ │
│ │ │ │ │
│ ▼ │ │ │
│┌──────────────────┐│ │ │
││start server in ├───────────►┌──────────────┐ │
││ dap server ││ │ │ start │ │
│└──────────────────┘│ │ │ TCP server │ │
│ │ │ └──────┬───────┘ │
│ │ │ │ │
│ │ │ ▼ │
│ │ │ ┌──────────────┐ │
│ │ │ │ sockconnect │ │
│ │◄══════════│ back │ │
│ │ │ │ to debuggee │ │
│ │ │ │ with │ │
│ │ parent_conn_addr
│ │ │ └──────────────┘ │
│ │ │ │
└────────────────────┘ └──────────────────┘
- The diagrams were drawn using venn.nvim.
Notes:
- debug.sethook allows to register a callback which will be called whenever a new lua line is executed, a call or a return is made.
DEBUGGEE DAP server
┌──────────────────┐ ┌────────────────┐
│┌───────────────┐ │ │ │ incoming
││debug.sethook │ │ │ ┌───────────┐ ◄───────────
││sents an event │ │ │ │ message │ │ DAP message
││(line, call, │ │ │ │ read by │ │
││ return) │ │ │ │ TCP server│ │
│└───────────────┘ │ │ └───────────┘ │
│ │ │ │ │ │
│ ▼ │ │ │ │
│┌─────────────┐ │ │ │ │
││check │ │ │ │ │
││messages in │ │ │ │ │
││M.server_messages│ │ │ │
│└─┬──┬────────┘ │ │ ▼ │
│NO│ │YES │ │┌──────────────┐│
│ │ └─► handle it│ ││insert message││
│ │ │ │◄═══════════╡ into debuggee││
│ │ │if │ ││using RPC ││
│ │ │breakpoint ││ socket in ││
│ │ ▼ │ ││M.server_messages
│ ▼ ┌──────────┐ │ │└──────────────┘│
│ │ frozen │ │ │ │
│ │ state │ │ │ │
│ └──────────┘ │ │ │
└──────────────────┘ └────────────────┘
- neovim is single-threaded. By going into a loop
it stops any execution. Even when calling
vim.wait
, neovim won't execute other any other lua code in the idle time. Note: This is not entierly true since code inside fast-api calls can still be executed.
DEBUGGEE DAP server
┌──────────────────┐ ┌────────────────┐
│ │ │ │ incoming
│ message loop │ │ ┌───────────┐ ◄───────────
│ ┌─────────────┐ │ │ │ message │ │ DAP message
│ ▼ │ │ │ │ read by │ │
│┌─────────────┐ │ │ │ │TCP server │ │
││check │ │ │ │ └───────────┘ │
││messages in │ │ │ │ │
││M.server_messages│ │ │ │
│└─┬──┬────────┘ │ │ ▼ │
│NO│ │YES │ │┌──────────────┐│
│ │ └─► handle it│ ││insert message││
│ │ │◄═══════════╡ into debuggee││
│ │ if │ │ │ ││using RPC ││
│ │ continue │ │ ││ socket in ││
│ │ msg │ │ │ ││M.server_messages
│ ▼ │ │ │ │└──────────────┘│
│┌──────────┐ │ │ │ │ │
││vim.wait │─│──┘ │ │ │
│└──────────┘ │ │ │ │
│ │ │ │ │
│ ┌──────────┘ │ │ │
│ │ break out │ │ │
│ ▼ of loop │ │ │
│ │ │ │
└──────────────────┘ └────────────────┘
For more detailed informations please refer to the source code available in src/. All the sources are written using ntangle.nvim. Please look at the plugin's documentation for the syntax and how sources are organised.