Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kdheepak/nvim-dap-julia
https://github.com/kdheepak/nvim-dap-julia
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/kdheepak/nvim-dap-julia
- Owner: kdheepak
- License: mit
- Created: 2024-06-29T04:36:31.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-08T03:16:58.000Z (6 months ago)
- Last Synced: 2024-10-31T17:38:30.002Z (2 months ago)
- Language: Lua
- Size: 15.6 KB
- Stars: 14
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# nvim-dap-julia
`nvim-dap-julia` is a Neovim plugin that integrates the
[Julia language debugger](https://github.com/julia-vscode/DebugAdapter.jl) with the
[Neovim Debug Adapter Protocol (DAP) client](https://github.com/mfussenegger/nvim-dap).https://github.com/kdheepak/nvim-dap-julia/assets/1813121/54019d2a-2843-436a-80f1-b9d2d7f126dd
### Setup
Using [`lazy.nvim`](https://github.com/folke/lazy.nvim):
```lua
return {
{
"mfussenegger/nvim-dap",
dependencies = {
"kdheepak/nvim-dap-julia",
config = function()
require("nvim-dap-julia").setup()
end,
},
},
}
```Here's the default configuration:
```lua
local nvim_dap_julia = require("nvim-dap-julia")
nvim_dap_julia.setup({
configurations = {
julia = {
{
type = "julia",
name = "Debug julia executable",
request = "launch",
program = "${file}",
projectDir = "${workspaceFolder}",
juliaEnv = "${workspaceFolder}",
exitAfterTaskReturns = false,
debugAutoInterpretAllModules = false,
stopOnEntry = true,
args = {},
},
},
},
adapters = {
julia = {
type = "server",
port = "${port}",
executable = {
command = "julia",
args = { "--project=" .. nvim_dap_julia.get_plugin_root(), nvim_dap_julia.get_debugger_script(), "${port}" },
},
options = {
max_retries = 100,
},
},
},})
```If you want to override a specific section, you can do that by passing the options to `setup({})`.
For example, if you want to override `juliaEnv` to allow the user to pick options, you can setup a
coroutine callback like so:```lua
local juliaEnvCallback = function()
return coroutine.create(function(dap_run_co)
local items = {
[[ ${file}: Active filename ]],
[[ ${fileBasename}: The current file's basename ]],
[[ ${fileDirname}: The current file's dirname ]],
[[ ${relativeFile}: The current file relative to current working directory ]],
[[ ${workspaceFolder}: The current working directory of Neovim ]],
[[ ${workspaceFolderBasename}: The name of the folder opened in Neovim ]],
}
vim.ui.select(items, { label = "juliaEnv> " }, function(choice)
coroutine.resume(dap_run_co, choice)
end)
end)
endlocal nvim_dap_julia = require("nvim-dap-julia")
nvim_dap_julia.setup({
configurations = {
julia = {
juliaEnv = juliaEnvCallback
}
}
})```
### Usage
To start a debug session, use the following command:
```vim
:DapContinue
```Set breakpoints in your Julia code by using the following command:
```vim
:DapToggleBreakpoint
```Control the debugging session with the following commands:
- `:DapContinue` - Continue execution.
- `:DapStepOver` - Step over the current line.
- `:DapStepInto` - Step into the current line.
- `:DapStepOut` - Step out of the current function.
- `:DapTerminate` - Terminate the debugging session.### Advanced Setup
This setup includes keyboard shortcuts, opens UI elements automatically, etc:
```lua
return {
{
"mfussenegger/nvim-dap",
dependencies = {
"rcarriga/nvim-dap-ui",
"theHamsta/nvim-dap-virtual-text",
"nvim-neotest/nvim-nio",
"kdheepak/nvim-dap-julia",
},
config = function()
local dap = require("dap")
local ui = require("dapui")require("dapui").setup()
require("nvim-dap-julia").setup()vim.keymap.set("n", "b", dap.toggle_breakpoint)
vim.keymap.set("n", "B", dap.run_to_cursor)vim.keymap.set("n", "", dap.continue)
vim.keymap.set("n", "", dap.step_into)
vim.keymap.set("n", "", dap.step_over)
vim.keymap.set("n", "", dap.step_out)
vim.keymap.set("n", "", dap.step_back)
vim.keymap.set("n", "", dap.restart)dap.listeners.before.attach.dapui_config = function()
ui.open()
end
dap.listeners.before.launch.dapui_config = function()
ui.open()
end
dap.listeners.before.event_terminated.dapui_config = function()
ui.close()
end
dap.listeners.before.event_exited.dapui_config = function()
ui.close()
end
end,
},
}
```