2022-01-01 22:13:13 +08:00
# nvim-cmp
A completion engine plugin for neovim written in Lua.
Completion sources are installed from external repositories and "sourced".
2023-06-08 21:15:37 +08:00
https://github.com/hrsh7th/nvim-cmp/assets/22756295/afa70011-9121-4e42-aedd-0153b630eeab
2022-01-01 22:13:13 +08:00
Readme!
====================
2023-06-08 21:15:37 +08:00
1. There is a GitHub issue that documents [breaking changes ](https://github.com/hrsh7th/nvim-cmp/issues/231 ) for nvim-cmp. Subscribe to the issue to be notified of upcoming breaking changes.
2022-01-01 22:13:13 +08:00
2. This is my hobby project. You can support me via GitHub sponsors.
2023-06-08 21:15:37 +08:00
3. Bug reports are welcome, but don't expect a fix unless you provide minimal configuration and steps to reproduce your issue.
4. The `cmp.mapping.preset.*` is pre-defined configuration that aims to mimic neovim's native like behavior. It can be changed without announcement. Please manage key-mapping by yourself.
2022-01-01 22:13:13 +08:00
Concept
====================
2022-04-13 10:40:59 +08:00
- Full support for LSP completion related capabilities
- Powerful customizability via Lua functions
2023-06-08 21:15:37 +08:00
- Smart handling of key mappings
2022-01-01 22:13:13 +08:00
- No flicker
2022-04-13 10:40:59 +08:00
2022-01-01 22:13:13 +08:00
Setup
====================
### Recommended Configuration
2023-06-08 21:15:37 +08:00
This example configuration uses `vim-plug` as the plugin manager and `vim-vsnip` as a snippet plugin.
2022-01-01 22:13:13 +08:00
2022-04-13 10:40:59 +08:00
```lua
2022-01-01 22:13:13 +08:00
call plug#begin(s:plug_dir)
Plug 'neovim/nvim-lspconfig'
Plug 'hrsh7th/cmp-nvim-lsp'
Plug 'hrsh7th/cmp-buffer'
Plug 'hrsh7th/cmp-path'
Plug 'hrsh7th/cmp-cmdline'
Plug 'hrsh7th/nvim-cmp'
" For vsnip users.
Plug 'hrsh7th/cmp-vsnip'
Plug 'hrsh7th/vim-vsnip'
" For luasnip users.
" Plug 'L3MON4D3/LuaSnip'
" Plug 'saadparwaiz1/cmp_luasnip'
" For ultisnips users.
" Plug 'SirVer/ultisnips'
" Plug 'quangnguyen30192/cmp-nvim-ultisnips'
" For snippy users.
" Plug 'dcampos/nvim-snippy'
" Plug 'dcampos/cmp-snippy'
call plug#end()
lua < < EOF
2023-06-08 21:15:37 +08:00
-- Set up nvim-cmp.
2022-01-01 22:13:13 +08:00
local cmp = require'cmp'
cmp.setup({
snippet = {
-- REQUIRED - you must specify a snippet engine
expand = function(args)
vim.fn["vsnip#anonymous"](args.body) -- For `vsnip` users.
-- require('luasnip').lsp_expand(args.body) -- For `luasnip` users.
2022-04-13 10:40:59 +08:00
-- require('snippy').expand_snippet(args.body) -- For `snippy` users.
2022-01-01 22:13:13 +08:00
-- vim.fn["UltiSnips#Anon"](args.body) -- For `ultisnips` users.
end,
},
2023-06-08 21:15:37 +08:00
window = {
-- completion = cmp.config.window.bordered(),
-- documentation = cmp.config.window.bordered(),
2022-01-01 22:13:13 +08:00
},
2023-06-08 21:15:37 +08:00
mapping = cmp.mapping.preset.insert({
['< C-b > '] = cmp.mapping.scroll_docs(-4),
['< C-f > '] = cmp.mapping.scroll_docs(4),
['< C-Space > '] = cmp.mapping.complete(),
['< C-e > '] = cmp.mapping.abort(),
['< CR > '] = cmp.mapping.confirm({ select = true }), -- Accept currently selected item. Set `select` to `false` to only confirm explicitly selected items.
}),
2022-01-01 22:13:13 +08:00
sources = cmp.config.sources({
{ name = 'nvim_lsp' },
{ name = 'vsnip' }, -- For vsnip users.
-- { name = 'luasnip' }, -- For luasnip users.
-- { name = 'ultisnips' }, -- For ultisnips users.
-- { name = 'snippy' }, -- For snippy users.
}, {
{ name = 'buffer' },
})
})
2022-04-13 10:40:59 +08:00
-- Set configuration for specific filetype.
cmp.setup.filetype('gitcommit', {
sources = cmp.config.sources({
2023-06-08 21:15:37 +08:00
{ name = 'git' }, -- You can specify the `git` source if [you were installed it ](https://github.com/petertriho/cmp-git ).
2022-04-13 10:40:59 +08:00
}, {
{ name = 'buffer' },
})
})
2023-06-08 21:15:37 +08:00
-- Use buffer source for `/` and `?` (if you enabled `native_menu` , this won't work anymore).
cmp.setup.cmdline({ '/', '?' }, {
mapping = cmp.mapping.preset.cmdline(),
2022-01-01 22:13:13 +08:00
sources = {
{ name = 'buffer' }
}
})
-- Use cmdline & path source for ':' (if you enabled `native_menu` , this won't work anymore).
cmp.setup.cmdline(':', {
2023-06-08 21:15:37 +08:00
mapping = cmp.mapping.preset.cmdline(),
2022-01-01 22:13:13 +08:00
sources = cmp.config.sources({
{ name = 'path' }
}, {
{ name = 'cmdline' }
})
})
2023-06-08 21:15:37 +08:00
-- Set up lspconfig.
local capabilities = require('cmp_nvim_lsp').default_capabilities()
2022-01-01 22:13:13 +08:00
-- Replace < YOUR_LSP_SERVER > with each lsp server you've enabled.
require('lspconfig')['< YOUR_LSP_SERVER > '].setup {
capabilities = capabilities
}
EOF
```
2023-06-08 21:15:37 +08:00
### Where can I find more completion sources?
2022-04-13 10:40:59 +08:00
2023-06-08 21:15:37 +08:00
Have a look at the [Wiki ](https://github.com/hrsh7th/nvim-cmp/wiki/List-of-sources ) and the `nvim-cmp` [GitHub topic ](https://github.com/topics/nvim-cmp ).
2022-01-01 22:13:13 +08:00
2023-06-08 21:15:37 +08:00
### Where can I find advanced configuration examples?
2022-01-01 22:13:13 +08:00
2023-06-08 21:15:37 +08:00
See the [Wiki ](https://github.com/hrsh7th/nvim-cmp/wiki ).