Nvim: move to nvim-cmp

This commit is contained in:
Robert Kmieć
2022-12-12 01:11:27 +01:00
parent ba30d83f9e
commit 68774a8c80
8 changed files with 172 additions and 147 deletions

View File

@@ -1,5 +1,4 @@
local nvim_lsp = require('lspconfig') local nvim_lsp = require('lspconfig')
local coq = require('coq')
local clangd_extensions = require('clangd_extensions') local clangd_extensions = require('clangd_extensions')
local lsp_signature = require('lsp_signature') local lsp_signature = require('lsp_signature')
@@ -53,30 +52,31 @@ local signs = {
vim.fn.sign_define(sign.name, { texthl = sign.name, text = sign.text, numhl = "" }) vim.fn.sign_define(sign.name, { texthl = sign.name, text = sign.text, numhl = "" })
end end
vim.lsp.handlers["textDocument/publishDiagnostics"] = vim.lsp.with( --vim.lsp.handlers["textDocument/publishDiagnostics"] = vim.lsp.with(
vim.lsp.diagnostic.on_publish_diagnostics, { -- vim.lsp.diagnostic.on_publish_diagnostics, {
signs = { -- signs = {
active = signs, -- active = signs,
--severity_limit = 'info', -- --severity_limit = 'info',
},
severity_sort = true,
underline = false,
update_in_insert = false,
--virtual_text = {
-- spacing = 40,
-- severity_limit = 'Warning',
-- }, -- },
virtual_text = false, -- severity_sort = true,
} -- underline = false,
) -- update_in_insert = false,
-- --virtual_text = {
-- -- spacing = 40,
-- -- severity_limit = 'Warning',
-- --},
-- virtual_text = false,
-- }
--)
--
local capabilities = require('cmp_nvim_lsp').default_capabilities()
nvim_lsp.groovyls.setup (coq.lsp_ensure_capabilities({ nvim_lsp.groovyls.setup({
cmd = { "java", "-jar", "/home/kmcr/tools/groovy-language-server/build/libs/groovy-language-server-all.jar" }, cmd = { "java", "-jar", "/home/kmcr/tools/groovy-language-server/build/libs/groovy-language-server-all.jar" },
on_attach = on_attach, on_attach = on_attach,
on_publish_diagnostics = diagnostic_handler, --on_publish_diagnostics = diagnostic_handler,
capabilities = vim.lsp.protocol.make_client_capabilities(), capabilities = capabilities
}) })
)
-- nvim_lsp.ccls.setup( -- nvim_lsp.ccls.setup(
-- coq.lsp_ensure_capabilities({ -- coq.lsp_ensure_capabilities({
@@ -92,14 +92,13 @@ nvim_lsp.groovyls.setup (coq.lsp_ensure_capabilities({
-- root_dir = nvim_lsp.util.root_pattern("compile_commands.json"), -- root_dir = nvim_lsp.util.root_pattern("compile_commands.json"),
-- on_attach = on_attach, -- on_attach = on_attach,
-- on_publish_diagnostics = diagnostic_handler, -- on_publish_diagnostics = diagnostic_handler,
-- capabilities = cmp.update_capabilities(vim.lsp.protocol.make_client_capabilities()),
-- flags = { -- flags = {
-- debounce_text_changes = 150, -- debounce_text_changes = 150,
-- }} -- }}
-- ) -- )
-- ) -- )
clangd_extensions.setup(coq.lsp_ensure_capabilities({ clangd_extensions.setup({
server = { server = {
on_attach = on_attach, on_attach = on_attach,
root_pattern = { root_pattern = {
@@ -109,16 +108,17 @@ clangd_extensions.setup(coq.lsp_ensure_capabilities({
'compile_commands.json', 'compile_commands.json',
'compile_flags.txt', 'compile_flags.txt',
'configure.ac', 'configure.ac',
} },
capabilities = capabilities
}, },
inlay_hints = { inlay_hints = {
max_len_align = true, max_len_align = true,
max_len_align_padding = 3, max_len_align_padding = 3,
right_align = true, right_align = true,
} }
})) })
nvim_lsp.pylsp.setup(coq.lsp_ensure_capabilities({ nvim_lsp.pylsp.setup({
settings = { settings = {
pylint = { pylint = {
enabled = false enabled = false
@@ -127,24 +127,24 @@ nvim_lsp.pylsp.setup(coq.lsp_ensure_capabilities({
enabled = false, enabled = false,
}, },
}, },
flags = { -- flags = {
debounce_text_changes = 150, -- debounce_text_changes = 150,
}, -- },
on_attach = on_attach, on_attach = on_attach,
on_publish_diagnostics = diagnostic_handler, capabilities = capabilities
capabilities = vim.lsp.protocol.make_client_capabilities(), --on_publish_diagnostics = diagnostic_handler,
})) })
-- Use a loop to conveniently call 'setup' on multiple servers and -- Use a loop to conveniently call 'setup' on multiple servers and
-- map buffer local keybindings when the language server attaches -- map buffer local keybindings when the language server attaches
local servers = { "cmake", "rust_analyzer", "bashls" } local servers = { "cmake", "rust_analyzer", "bashls" }
for _, lsp in ipairs(servers) do for _, lsp in ipairs(servers) do
nvim_lsp[lsp].setup(coq.lsp_ensure_capabilities({ nvim_lsp[lsp].setup({
on_attach = on_attach, on_attach = on_attach,
on_publish_diagnostics = diagnostic_handler, --on_publish_diagnostics = diagnostic_handler,
capabilities = vim.lsp.protocol.make_client_capabilities(), capabilities = capabilities,
flags = { -- flags = {
debounce_text_changes = 150, -- debounce_text_changes = 150,
} -- }
})) })
end end

View File

@@ -1,73 +1,68 @@
-- Setup nvim-cmp. local cmp = require'cmp'
--local cmp = require'cmp'
-- cmp.setup({
--cmp.setup({ snippet = {
-- snippet = { expand = function(args)
-- expand = function(args) require('snippy').expand_snippet(args.body)
-- -- For `vsnip` user. end,
-- -- vim.fn["vsnip#anonymous"](args.body) },
-- window = {
-- -- For `luasnip` user. completion = cmp.config.window.bordered(),
-- -- require('luasnip').lsp_expand(args.body) documentation = cmp.config.window.bordered(),
-- },
-- -- For `ultisnips` user. mapping = cmp.mapping.preset.insert({
-- vim.fn["UltiSnips#Anon"](args.body) ['<C-b>'] = cmp.mapping.scroll_docs(-4),
-- end, ['<C-f>'] = cmp.mapping.scroll_docs(4),
-- }, ['<C-Space>'] = cmp.mapping.complete(),
-- mapping = cmp.mapping.preset.insert({ ['<C-e>'] = cmp.mapping.abort(),
-- ['<C-b>'] = cmp.mapping(cmp.mapping.scroll_docs(-4), { 'i', 'c' }), ['<CR>'] = cmp.mapping.confirm({ select = false }),
-- ['<C-f>'] = cmp.mapping(cmp.mapping.scroll_docs(4), { 'i', 'c' }), }),
-- ['<C-Space>'] = cmp.mapping(cmp.mapping.complete(), { 'i', 'c' }), sources = cmp.config.sources({
-- ['<tab>'] = cmp.mapping.confirm({ select = true }), { name = 'nvim_lsp' },
-- ['<C-e>'] = cmp.mapping({ { name = 'path' },
-- i = cmp.mapping.abort(), { name = 'snippy' },
-- c = cmp.mapping.close(), { name = 'calc' },
-- }), { name = 'cmp_matlab' },
-- }), { name = 'cmp_git' },
-- sources = cmp.config.sources({ }, {
-- { name = 'nvim_lsp' }, { name = 'buffer', keyword_length = 5, max_item_count = 10, priority = -5 },
-- }),
-- { name = 'path' }, sorting = {
-- comparators = {
-- { name = 'ultisnips' }, cmp.config.compare.offset,
-- cmp.config.compare.exact,
-- { name = 'calc' }, cmp.config.compare.recently_used,
-- require("clangd_extensions.cmp_scores"),
-- { name = 'cmp_matlab' }, cmp.config.compare.kind,
-- cmp.config.compare.sort_text,
-- { name = 'cmp_git' }, cmp.config.compare.length,
-- }, { cmp.config.compare.order,
-- { name = 'buffer', keyword_length = 5, max_item_count = 10, priority = -5 }, },
-- }), },
-- --experimental = { })
-- -- native_menu = false
-- --} cmp.setup.cmdline({'/', '?'}, {
-- mapping = cmp.mapping.preset.cmdline(),
-- sorting = { sources = {
-- comparators = { { name = 'buffer' }
-- cmp.config.compare.offset, }
-- cmp.config.compare.exact, })
-- cmp.config.compare.recently_used,
-- require("clangd_extensions.cmp_scores"), cmp.setup.cmdline(':', {
-- cmp.config.compare.kind, mapping = cmp.mapping.preset.cmdline(),
-- cmp.config.compare.sort_text, sources = cmp.config.sources({
-- cmp.config.compare.length, { name = 'path' }
-- cmp.config.compare.order, }, {
-- }, { name = 'cmdline' }
-- }, })
--}) })
--
--cmp.setup.cmdline('/', { cmp.setup.filetype('gitcommit', {
-- sources = { sources = cmp.config.sources({
-- { name = 'buffer' } {name = 'cmp_git' },
-- } }, {
--}) {name = 'buffer' }
-- })
--cmp.setup.cmdline(':', { })
-- sources = {
-- { name = 'cmdline' } require("cmp_git").setup()
-- },
-- mapping = cmp.mapping.preset.cmdline()
--})
--
--require("cmp_git").setup()

View File

@@ -0,0 +1,11 @@
require('snippy').setup({
mappings = {
is = {
['<Tab>'] = 'expand_or_advance',
['<S-Tab>'] = 'previous',
},
nx = {
['<leader>x'] = 'cut_text',
},
},
})

View File

@@ -1,8 +0,0 @@
" Set completeopt to have a better completion experience
"set completeopt=menuone,noinsert,noselect
let g:completion_enable_snippet = 'UltiSnips'
"iunmap <Tab>
"map <c-s> <C-R>=UltiSnips#ExpandSnippet()<CR>
"let g:UltiSnipsExpandTrigger="<c-s>"
let g:UltiSnipsJumpForwardTrigger="<tab>"
let g:UltiSnipsJumpBackwardTrigger="<S-tab>"

View File

@@ -1,13 +1,30 @@
let g:cmake_build_options = [ "-j10" ] "let g:cmake_build_options = [ "-j10" ]
"
"let g:cmake_root_markers = ['.svn']
"
"
"let g:cmake_jump_on_error = 0 " We do not want to focus the console
"augroup vim-cmake-group
"autocmd User CMakeBuildFailed :cfirst
"augroup END
"
"augroup vim-cmake-group
"autocmd! User CMakeBuildSucceeded CMakeClose
"augroup END
let g:cmake_root_markers = ['.svn'] lua << EOF
require("cmake-tools").setup {
cmake_command = "cmake",
let g:cmake_jump_on_error = 0 " We do not want to focus the console cmake_build_directory = "build",
augroup vim-cmake-group cmake_generate_options = { "-D", "CMAKE_EXPORT_COMPILE_COMMANDS=1" },
autocmd User CMakeBuildFailed :cfirst cmake_build_options = {},
augroup END cmake_console_size = 10, -- cmake output window height
cmake_show_console = "always", -- "always", "only_on_error"
augroup vim-cmake-group cmake_dap_configuration = { name = "cpp", type = "codelldb", request = "launch" }, -- dap configuration, optional
autocmd! User CMakeBuildSucceeded CMakeClose --cmake_dap_open_command = require("dap").repl.open, -- optional
augroup END cmake_variants_message = {
short = { show = true },
long = { show = true, max_length = 40 }
}
}
EOF

View File

@@ -0,0 +1 @@
../available/snippets.rc.lua

View File

@@ -1 +0,0 @@
../available/ultisnips.rc.vim

View File

@@ -25,7 +25,7 @@ call plug#begin('~/.config/nvim/plugins')
"Plug 'RRethy/vim-illuminate' "Plug 'RRethy/vim-illuminate'
Plug 'Saecki/crates.nvim' | Plug 'jose-elias-alvarez/null-ls.nvim' Plug 'Saecki/crates.nvim' | Plug 'jose-elias-alvarez/null-ls.nvim'
Plug 'andrewferrier/debugprint.nvim' Plug 'andrewferrier/debugprint.nvim'
Plug 'cdelledonne/vim-cmake' Plug 'Civitasv/cmake-tools.nvim'
Plug 'danymat/neogen' Plug 'danymat/neogen'
Plug 'ftilde/vim-ugdb' Plug 'ftilde/vim-ugdb'
Plug 'jubnzv/virtual-types.nvim' Plug 'jubnzv/virtual-types.nvim'
@@ -40,14 +40,24 @@ Plug 'romgrk/nvim-treesitter-context'
" }}} " }}}
" Completion {{{ " Completion {{{
Plug 'ms-jpq/coq.artifacts', {'branch': 'artifacts'} Plug 'hrsh7th/cmp-buffer'
Plug 'ms-jpq/coq_nvim' Plug 'hrsh7th/cmp-cmdline'
Plug 'petertriho/cmp-git'
Plug 'hrsh7th/cmp-nvim-lsp'
Plug 'hrsh7th/cmp-path'
Plug 'hrsh7th/nvim-cmp'
" }}}
" Snippets {{{
"Plug 'fhill2/telescope-ultisnips.nvim'
Plug 'dcampos/cmp-snippy'
Plug 'dcampos/nvim-snippy'
Plug 'honza/vim-snippets'
" }}} " }}}
" Files switch, jump and grep-like tools {{{ " Files switch, jump and grep-like tools {{{
"Plug 'inside/vim-search-pulse' "Plug 'inside/vim-search-pulse'
Plug 'MunifTanjim/nui.nvim' Plug 'MunifTanjim/nui.nvim'
Plug 'fhill2/telescope-ultisnips.nvim'
Plug 'ggandor/leap.nvim' Plug 'ggandor/leap.nvim'
Plug 'kyazdani42/nvim-tree.lua' Plug 'kyazdani42/nvim-tree.lua'
Plug 'kyazdani42/nvim-web-devicons' Plug 'kyazdani42/nvim-web-devicons'
@@ -247,7 +257,7 @@ set shortmess-=F
set signcolumn=auto set signcolumn=auto
set wildmode=longest,list,full set wildmode=longest,list,full
set completeopt=menuone,noselect set completeopt=menu,menuone,noselect
set mouse= set mouse=