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
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
|
local M = {}
M.config = function()
lvim.builtin.dap = {
active = true,
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 = {
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",
},
-- Use this to override mappings for specific elements
element_mappings = {},
expand_lines = true,
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",
},
},
controls = {
enabled = true,
-- Display controls in this element
element = "repl",
icons = {
pause = "",
play = "",
step_into = "",
step_over = "",
step_out = "",
step_back = "",
run_last = "",
terminate = "",
},
},
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>" },
},
},
windows = { indent = 1 },
render = {
max_type_length = nil, -- Can be integer or nil.
max_value_lines = 100, -- Can be integer or nil.
},
},
},
}
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)
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
|