local lsp = require('lsp-zero') local cmp = require('cmp') local luasnip = require('luasnip') local dap = require('dap') local dapui = require('dapui') require('mason').setup({}) require('mason-nvim-dap').setup({ ensure_installed = { 'cpptools', 'cppdbg', }, }) require('mason-lspconfig').setup({}) dap.configurations = { cpp = { { name = "Launch", type = "codelldb", request = "launch", program = function() return vim.fn.input('Path to executable: ', vim.fn.getcwd() .. '/build/', 'file') end, cwd = '${workspaceFolder}', stopOnEntry = true, }, }, } dap.adapters.codelldb = { type = 'server', port = '13000', host = '127.0.0.1', executable = { command = vim.fn.stdpath('data') .. '/mason/bin/codelldb', args = {"--port", "13000"} } } dapui.setup({ icons = { expanded = "➡️", collapsed = "⬇️" }, mappings = { open = "o", remove = "d", edit = "e", repl = "r", toggle = "t", }, expand_lines = vim.fn.has("nvim-0.7"), layouts = { { elements = { "scopes", "stacks", "watches" }, size = 0.17, position = "left" }, { elements = { "repl", "console", "breakpoints", }, size = 0.15, position = "bottom", }, }, floating = { max_height = nil, max_width = nil, border = "single", mappings = { close = { "q", "" }, }, }, windows = { indent = 1 }, render = { max_type_length = nil, }, }) 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 vim.keymap.set("n", "ds", function() dap.continue() dapui.toggle({}) end) vim.keymap.set("n", "de", function() dapui.toggle({}) dap.terminate() require("notify")("Debugger session ended", "warn") end) vim.keymap.set("n", "dC", function() require('dap').clear_breakpoints() require("notify")("Cleared breakpoints", "warn") end) vim.fn.sign_define('DapBreakpoint',{ text ='🔴', texthl ='', linehl ='', numhl =''}) vim.fn.sign_define('DapStopped',{ text ='▶️', texthl ='', linehl ='', numhl =''}) lsp.preset({ name = 'recommended', }) lsp.ensure_installed({ 'tsserver', 'clangd', }) lsp.configure('clangd', { capabilities = { offsetEncoding = { "utf-16" } } }) local cmp_mode = { behavior = cmp.SelectBehavior.Replace } local cmp_mappings = lsp.defaults.cmp_mappings({ [""] = cmp.mapping(function(fallback) if (cmp.visible()) then cmp.select_next_item(cmp_mode) elseif luasnip.expand_or_jumpable() then luasnip.expand_or_jump() else fallback() end cmp.mapping.select_next_item(cmp_mode) end, { 'i', 's' }), [""] = cmp.mapping.select_prev_item(cmp_mode), }) -- unmap arrow keys cmp_mappings[""] = nil cmp_mappings[""] = nil lsp.setup_nvim_cmp({ preselect = require('cmp').PreselectMode.None, completion = { completeopt = 'menu,menuone,noinsert,noselect' }, mapping = cmp_mappings, }) lsp.on_attach(function(_, bufnr) vim.api.nvim_buf_set_option(bufnr, 'omnifunc', 'v:lua.vim.lsp.omnifunc') local opts = { noremap = true, silent = true, buffer = bufnr } vim.keymap.set('n', 'gD', 'lua vim.lsp.buf.definition()', opts) vim.keymap.set('n', 'gT', 'lua vim.lsp.buf.type_definition()', opts) vim.keymap.set('n', 'gR', 'lua vim.lsp.buf.references()', opts) -- diagnostics vim.keymap.set('n', 'gn', 'lua vim.diagnostic.goto_next()', opts) vim.keymap.set('n', 'gN', 'lua vim.diagnostic.goto_prev()', opts) -- action & rename vim.keymap.set('n', '', 'Lspsaga code_action', opts) vim.keymap.set('n', 'gr', 'Lspsaga rename', opts) -- overwrite the defaults vim.keymap.set('n', 'gi', 'lua vim.lsp.buf.implementation()', opts) vim.keymap.set('n', 'K', 'Lspsaga hover_doc', opts) -- jump forward/backward up/down the call list vim.keymap.set('n', 'gI', 'Lspsaga incoming_calls', opts) vim.keymap.set('n', 'gO', 'Lspsaga outgoing_calls', opts) -- Sexy LSP vim.keymap.set('n', 'gd', 'Lspsaga peek_definition', opts) vim.keymap.set('n', 'gt', 'Lspsaga peek_type_definition', opts) vim.keymap.set('n', 'gr', 'Lspsaga lsp_finder', opts) -- CLANGFORMATTTTT vim.keymap.set('n', 'gf', 'lua vim.lsp.buf.format()', opts) vim.keymap.set('n', 'gg', 'ClangdSwitchSourceHeader', opts) vim.keymap.set('n', 'gw', 'StripWhitespace', opts) end) local rust_lsp = lsp.build_options('rust_analyzer', { --cmd = { "/home/benk/programming/rust-analyzer/target/release/rust-analyzer" }, }) require('rust-tools').setup({ server = rust_lsp, tools = { inlay_hints = { auto = true, show_parameter_hints = true, parameter_hints_prefix = " ", other_hints_prefix = " ", } }, }) lsp.setup() cmp.setup.cmdline('/', { sources = { { name = 'buffer' } } }) cmp.setup.cmdline(':', { sources = cmp.config.sources({ { name = 'path' } }, { { name = 'cmdline' } }) }) lsp.set_preferences({ suggest_lsp_servers = false, sign_icons = { error = '', warn = '', hint = '', info = '' } }) local cmp_kinds = { Text = "", Method = "", Function = "", Constructor = "", Field = "ﴲ", Variable = "", Class = "", Interface = "ﰮ", Module = "", Property = "襁", Unit = "", Value = "", Enum = "練", Keyword = "", Snippet = "", Color = "", File = "", Reference = "", Folder = "", EnumMember = "", Constant = "ﲀ", Struct = "ﳤ", Event = "", Operator = "", TypeParameter = "" } local cmp_config = { window = { completion = cmp.config.window.bordered(), documentation = cmp.config.window.bordered() }, completion = { completeopt = "menu,menuone,preview,noselect", }, snippet = { expand = function(args) luasnip.lsp_expand(args.body) end, }, formatting = { fields = { "kind", "abbr", "menu" }, format = function(entry, vim_item) vim_item.menu = ({ buffer = "", nvim_lsp = "", })[entry.source.name] local kind = vim_item.kind vim_item.kind = " " .. (cmp_kinds[kind] or "?") .. "" local source = entry.source.name vim_item.menu = "[" .. source .. "]" return vim_item end, }, sorting = { priority_weight = 1.0, }, matching = { disallow_fuzzy_matching = true, disallow_fullfuzzy_matching = true, disallow_partial_fuzzy_matching = true, disallow_partial_matching = false, disallow_prefix_unmatching = true, }, performance = { max_view_entries = 20, }, } cmp.setup(cmp_config) vim.api.nvim_set_hl(0, "CmpItemMenu", { italic = true }) vim.diagnostic.config({ virtual_text = true })