Nvim: move to nvim-cmp
This commit is contained in:
@@ -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')
|
||||||
|
|
||||||
@@ -47,36 +46,37 @@ local signs = {
|
|||||||
{ name = "DiagnosticSignWarn", text = "" },
|
{ name = "DiagnosticSignWarn", text = "" },
|
||||||
{ name = "DiagnosticSignHint", text = "" },
|
{ name = "DiagnosticSignHint", text = "" },
|
||||||
{ name = "DiagnosticSignInfo", text = "" },
|
{ name = "DiagnosticSignInfo", text = "" },
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, sign in ipairs(signs) do
|
for _, sign in ipairs(signs) do
|
||||||
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,
|
-- severity_sort = true,
|
||||||
underline = false,
|
-- underline = false,
|
||||||
update_in_insert = false,
|
-- update_in_insert = false,
|
||||||
--virtual_text = {
|
-- --virtual_text = {
|
||||||
-- spacing = 40,
|
-- -- spacing = 40,
|
||||||
-- severity_limit = 'Warning',
|
-- -- severity_limit = 'Warning',
|
||||||
--},
|
-- --},
|
||||||
virtual_text = false,
|
-- 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
|
||||||
|
|||||||
@@ -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()
|
|
||||||
|
|||||||
11
.config/nvim/after/available/snippets.rc.lua
Normal file
11
.config/nvim/after/available/snippets.rc.lua
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
require('snippy').setup({
|
||||||
|
mappings = {
|
||||||
|
is = {
|
||||||
|
['<Tab>'] = 'expand_or_advance',
|
||||||
|
['<S-Tab>'] = 'previous',
|
||||||
|
},
|
||||||
|
nx = {
|
||||||
|
['<leader>x'] = 'cut_text',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
@@ -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>"
|
|
||||||
@@ -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
|
||||||
|
|||||||
1
.config/nvim/after/plugin/snippets.rc.lua
Symbolic link
1
.config/nvim/after/plugin/snippets.rc.lua
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../available/snippets.rc.lua
|
||||||
@@ -1 +0,0 @@
|
|||||||
../available/ultisnips.rc.vim
|
|
||||||
@@ -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=
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user