1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
|
local M = {}
M.config = function()
lvim.builtin.dap = {
active = true,
on_config_done = nil,
breakpoint = {
text = lvim.icons.ui.Bug,
texthl = "DiagnosticSignError",
linehl = "",
numhl = "",
},
breakpoint_rejected = {
text = lvim.icons.ui.Bug,
texthl = "DiagnosticSignError",
linehl = "",
numhl = "",
},
stopped = {
text = lvim.icons.ui.BoldArrowRight,
texthl = "DiagnosticSignWarn",
linehl = "Visual",
numhl = "DiagnosticSignWarn",
},
log = {
level = "info",
},
ui = {
auto_open = true,
notify = {
threshold = vim.log.levels.INFO,
},
config = {
expand_lines = true,
icons = { expanded = "", collapsed = "", circular = "" },
mappings = {
-- Use a table to apply multiple mappings
expand = { "<CR>", "<2-LeftMouse>" },
open = "o",
remove = "d",
edit = "e",
repl = "r",
toggle = "t",
},
layouts = {
{
elements = {
{ id = "scopes", size = 0.33 },
{ id = "breakpoints", size = 0.17 },
{ id = "stacks", size = 0.25 },
{ id = "watches", size = 0.25 },
},
size = 0.33,
position = "right",
},
{
elements = {
{ id = "repl", size = 0.45 },
{ id = "console", size = 0.55 },
},
size = 0.27,
position = "bottom",
},
},
floating = {
max_height = 0.9,
max_width = 0.5, -- Floats will be treated as percentage of your screen.
border = vim.g.border_chars, -- Border style. Can be 'single', 'double' or 'rounded'
mappings = {
close = { "q", "<Esc>" },
},
},
},
},
}
end
M.setup = function()
local status_ok, dap = pcall(require, "dap")
if not status_ok then
return
end
if lvim.use_icons then
vim.fn.sign_define("DapBreakpoint", lvim.builtin.dap.breakpoint)
vim.fn.sign_define("DapBreakpointRejected", lvim.builtin.dap.breakpoint_rejected)
vim.fn.sign_define("DapStopped", lvim.builtin.dap.stopped)
end
dap.set_log_level(lvim.builtin.dap.log.level)
if lvim.builtin.dap.on_config_done then
lvim.builtin.dap.on_config_done(dap)
end
end
M.setup_ui = function()
local status_ok, dap = pcall(require, "dap")
if not status_ok then
return
end
local dapui = require "dapui"
dapui.setup(lvim.builtin.dap.ui.config)
if lvim.builtin.dap.ui.auto_open then
dap.listeners.after.event_initialized["dapui_config"] = function()
dapui.open()
end
-- dap.listeners.before.event_terminated["dapui_config"] = function()
-- dapui.close()
-- end
-- dap.listeners.before.event_exited["dapui_config"] = function()
-- dapui.close()
-- end
end
local Log = require "lvim.core.log"
-- until rcarriga/nvim-dap-ui#164 is fixed
local function notify_handler(msg, level, opts)
if level >= lvim.builtin.dap.ui.notify.threshold then
return vim.notify(msg, level, opts)
end
opts = vim.tbl_extend("keep", opts or {}, {
title = "dap-ui",
icon = "",
on_open = function(win)
vim.api.nvim_buf_set_option(vim.api.nvim_win_get_buf(win), "filetype", "markdown")
end,
})
-- vim_log_level can be omitted
if level == nil then
level = Log.levels["INFO"]
elseif type(level) == "string" then
level = Log.levels[(level):upper()] or Log.levels["INFO"]
else
-- https://github.com/neovim/neovim/blob/685cf398130c61c158401b992a1893c2405cd7d2/runtime/lua/vim/lsp/log.lua#L5
level = level + 1
end
msg = string.format("%s: %s", opts.title, msg)
Log:add_entry(level, msg)
end
local dapui_ok, _ = xpcall(function()
require("dapui.util").notify = notify_handler
end, debug.traceback)
if not dapui_ok then
Log:debug "Unable to override dap-ui logging level"
end
end
return M
|