284 lines
10 KiB
Markdown
284 lines
10 KiB
Markdown
|
<p align="center">
|
|||
|
<a href="https://www.vim.org/scripts/script.php?script_id=5779">
|
|||
|
<img alt="Coc Logo" src="https://user-images.githubusercontent.com/251450/55009068-f4ed2780-501c-11e9-9a3b-cf3aa6ab9272.png" height="160" />
|
|||
|
</a>
|
|||
|
<p align="center">Make your Vim/Neovim as smart as VSCode.</p>
|
|||
|
<p align="center">
|
|||
|
<a href="/LICENSE.md"><img alt="Software License" src="https://img.shields.io/badge/license-MIT-brightgreen.svg?style=flat-square"></a>
|
|||
|
<a href="https://github.com/neoclide/coc.nvim/actions"><img alt="Actions" src="https://img.shields.io/github/workflow/status/neoclide/coc.nvim/coc.nvim%20CI?style=flat-square"></a>
|
|||
|
<a href="/doc/coc.txt"><img alt="Doc" src="https://img.shields.io/badge/doc-%3Ah%20coc.txt-brightgreen.svg?style=flat-square"></a>
|
|||
|
<a href="https://gitter.im/neoclide/coc.nvim"><img alt="Gitter" src="https://img.shields.io/gitter/room/neoclide/coc.nvim.svg?style=flat-square"></a>
|
|||
|
</p>
|
|||
|
</p>
|
|||
|
|
|||
|
---
|
|||
|
|
|||
|
<img alt="Gif" src="https://user-images.githubusercontent.com/251450/55285193-400a9000-53b9-11e9-8cff-ffe4983c5947.gif" width="60%" />
|
|||
|
|
|||
|
_True snippet and additional text editing support_
|
|||
|
|
|||
|
## Why?
|
|||
|
|
|||
|
- 🚀 **Fast**: [instant increment completion](https://github.com/neoclide/coc.nvim/wiki/Completion-with-sources), increment buffer sync using buffer update events.
|
|||
|
- 💎 **Reliable**: typed language, tested with CI.
|
|||
|
- 🌟 **Featured**: [full LSP support](https://github.com/neoclide/coc.nvim/wiki/Language-servers#supported-features)
|
|||
|
- ❤️ **Flexible**: [configured like VSCode](https://github.com/neoclide/coc.nvim/wiki/Using-the-configuration-file), [extensions work like in VSCode](https://github.com/neoclide/coc.nvim/wiki/Using-coc-extensions)
|
|||
|
|
|||
|
## Quick Start
|
|||
|
|
|||
|
Install [nodejs](https://nodejs.org/en/download/) >= 10.12:
|
|||
|
|
|||
|
```sh
|
|||
|
curl -sL install-node.now.sh/lts | bash
|
|||
|
```
|
|||
|
|
|||
|
For [vim-plug](https://github.com/junegunn/vim-plug) users:
|
|||
|
|
|||
|
```vim
|
|||
|
" Use release branch (recommend)
|
|||
|
Plug 'neoclide/coc.nvim', {'branch': 'release'}
|
|||
|
|
|||
|
" Or build from source code by using yarn: https://yarnpkg.com
|
|||
|
Plug 'neoclide/coc.nvim', {'do': 'yarn install --frozen-lockfile'}
|
|||
|
```
|
|||
|
|
|||
|
in your `.vimrc` or `init.vim`, then restart Vim and run `:PlugInstall`.
|
|||
|
|
|||
|
Checkout [Install
|
|||
|
coc.nvim](https://github.com/neoclide/coc.nvim/wiki/Install-coc.nvim) for
|
|||
|
more info.
|
|||
|
|
|||
|
You **have to** install coc extension or configure language servers for
|
|||
|
LSP support.
|
|||
|
|
|||
|
Install extensions like:
|
|||
|
|
|||
|
:CocInstall coc-json coc-tsserver
|
|||
|
|
|||
|
Or configure language server in `coc-settings.json` opened by
|
|||
|
`:CocConfig`, like:
|
|||
|
|
|||
|
```json
|
|||
|
{
|
|||
|
"languageserver": {
|
|||
|
"go": {
|
|||
|
"command": "gopls",
|
|||
|
"rootPatterns": ["go.mod"],
|
|||
|
"trace.server": "verbose",
|
|||
|
"filetypes": ["go"]
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
```
|
|||
|
|
|||
|
Checkout wiki for more details:
|
|||
|
|
|||
|
- [Completion with sources](https://github.com/neoclide/coc.nvim/wiki/Completion-with-sources)
|
|||
|
- [Using the configuration file](https://github.com/neoclide/coc.nvim/wiki/Using-the-configuration-file)
|
|||
|
- [Using coc extensions](https://github.com/neoclide/coc.nvim/wiki/Using-coc-extensions)
|
|||
|
- [Configure language servers](https://github.com/neoclide/coc.nvim/wiki/Language-servers)
|
|||
|
- [F.A.Q](https://github.com/neoclide/coc.nvim/wiki/F.A.Q)
|
|||
|
|
|||
|
Checkout `:h coc-nvim` for vim interface.
|
|||
|
|
|||
|
## Example vim configuration
|
|||
|
|
|||
|
Configuration is required to make coc.nvim easier to work with, since it
|
|||
|
doesn't change your key-mappings or Vim options. This is done as much as
|
|||
|
possible to avoid conflict with your other plugins.
|
|||
|
|
|||
|
**❗️Important**: Some Vim plugins could change key mappings. Please use
|
|||
|
`:verbose imap <tab>` to make sure that your keymap has taken effect.
|
|||
|
|
|||
|
```vim
|
|||
|
" TextEdit might fail if hidden is not set.
|
|||
|
set hidden
|
|||
|
|
|||
|
" Some servers have issues with backup files, see #649.
|
|||
|
set nobackup
|
|||
|
set nowritebackup
|
|||
|
|
|||
|
" Give more space for displaying messages.
|
|||
|
set cmdheight=2
|
|||
|
|
|||
|
" Having longer updatetime (default is 4000 ms = 4 s) leads to noticeable
|
|||
|
" delays and poor user experience.
|
|||
|
set updatetime=300
|
|||
|
|
|||
|
" Don't pass messages to |ins-completion-menu|.
|
|||
|
set shortmess+=c
|
|||
|
|
|||
|
" Always show the signcolumn, otherwise it would shift the text each time
|
|||
|
" diagnostics appear/become resolved.
|
|||
|
if has("patch-8.1.1564")
|
|||
|
" Recently vim can merge signcolumn and number column into one
|
|||
|
set signcolumn=number
|
|||
|
else
|
|||
|
set signcolumn=yes
|
|||
|
endif
|
|||
|
|
|||
|
" Use tab for trigger completion with characters ahead and navigate.
|
|||
|
" NOTE: Use command ':verbose imap <tab>' to make sure tab is not mapped by
|
|||
|
" other plugin before putting this into your config.
|
|||
|
inoremap <silent><expr> <TAB>
|
|||
|
\ pumvisible() ? "\<C-n>" :
|
|||
|
\ <SID>check_back_space() ? "\<TAB>" :
|
|||
|
\ coc#refresh()
|
|||
|
inoremap <expr><S-TAB> pumvisible() ? "\<C-p>" : "\<C-h>"
|
|||
|
|
|||
|
function! s:check_back_space() abort
|
|||
|
let col = col('.') - 1
|
|||
|
return !col || getline('.')[col - 1] =~# '\s'
|
|||
|
endfunction
|
|||
|
|
|||
|
" Use <c-space> to trigger completion.
|
|||
|
if has('nvim')
|
|||
|
inoremap <silent><expr> <c-space> coc#refresh()
|
|||
|
else
|
|||
|
inoremap <silent><expr> <c-@> coc#refresh()
|
|||
|
endif
|
|||
|
|
|||
|
" Make <CR> auto-select the first completion item and notify coc.nvim to
|
|||
|
" format on enter, <cr> could be remapped by other vim plugin
|
|||
|
inoremap <silent><expr> <cr> pumvisible() ? coc#_select_confirm()
|
|||
|
\: "\<C-g>u\<CR>\<c-r>=coc#on_enter()\<CR>"
|
|||
|
|
|||
|
" Use `[g` and `]g` to navigate diagnostics
|
|||
|
" Use `:CocDiagnostics` to get all diagnostics of current buffer in location list.
|
|||
|
nmap <silent> [g <Plug>(coc-diagnostic-prev)
|
|||
|
nmap <silent> ]g <Plug>(coc-diagnostic-next)
|
|||
|
|
|||
|
" GoTo code navigation.
|
|||
|
nmap <silent> gd <Plug>(coc-definition)
|
|||
|
nmap <silent> gy <Plug>(coc-type-definition)
|
|||
|
nmap <silent> gi <Plug>(coc-implementation)
|
|||
|
nmap <silent> gr <Plug>(coc-references)
|
|||
|
|
|||
|
" Use K to show documentation in preview window.
|
|||
|
nnoremap <silent> K :call <SID>show_documentation()<CR>
|
|||
|
|
|||
|
function! s:show_documentation()
|
|||
|
if (index(['vim','help'], &filetype) >= 0)
|
|||
|
execute 'h '.expand('<cword>')
|
|||
|
elseif (coc#rpc#ready())
|
|||
|
call CocActionAsync('doHover')
|
|||
|
else
|
|||
|
execute '!' . &keywordprg . " " . expand('<cword>')
|
|||
|
endif
|
|||
|
endfunction
|
|||
|
|
|||
|
" Highlight the symbol and its references when holding the cursor.
|
|||
|
autocmd CursorHold * silent call CocActionAsync('highlight')
|
|||
|
|
|||
|
" Symbol renaming.
|
|||
|
nmap <leader>rn <Plug>(coc-rename)
|
|||
|
|
|||
|
" Formatting selected code.
|
|||
|
xmap <leader>f <Plug>(coc-format-selected)
|
|||
|
nmap <leader>f <Plug>(coc-format-selected)
|
|||
|
|
|||
|
augroup mygroup
|
|||
|
autocmd!
|
|||
|
" Setup formatexpr specified filetype(s).
|
|||
|
autocmd FileType typescript,json setl formatexpr=CocAction('formatSelected')
|
|||
|
" Update signature help on jump placeholder.
|
|||
|
autocmd User CocJumpPlaceholder call CocActionAsync('showSignatureHelp')
|
|||
|
augroup end
|
|||
|
|
|||
|
" Applying codeAction to the selected region.
|
|||
|
" Example: `<leader>aap` for current paragraph
|
|||
|
xmap <leader>a <Plug>(coc-codeaction-selected)
|
|||
|
nmap <leader>a <Plug>(coc-codeaction-selected)
|
|||
|
|
|||
|
" Remap keys for applying codeAction to the current buffer.
|
|||
|
nmap <leader>ac <Plug>(coc-codeaction)
|
|||
|
" Apply AutoFix to problem on the current line.
|
|||
|
nmap <leader>qf <Plug>(coc-fix-current)
|
|||
|
|
|||
|
" Map function and class text objects
|
|||
|
" NOTE: Requires 'textDocument.documentSymbol' support from the language server.
|
|||
|
xmap if <Plug>(coc-funcobj-i)
|
|||
|
omap if <Plug>(coc-funcobj-i)
|
|||
|
xmap af <Plug>(coc-funcobj-a)
|
|||
|
omap af <Plug>(coc-funcobj-a)
|
|||
|
xmap ic <Plug>(coc-classobj-i)
|
|||
|
omap ic <Plug>(coc-classobj-i)
|
|||
|
xmap ac <Plug>(coc-classobj-a)
|
|||
|
omap ac <Plug>(coc-classobj-a)
|
|||
|
|
|||
|
" Remap <C-f> and <C-b> for scroll float windows/popups.
|
|||
|
" Note coc#float#scroll works on neovim >= 0.4.3 or vim >= 8.2.0750
|
|||
|
nnoremap <nowait><expr> <C-f> coc#float#has_scroll() ? coc#float#scroll(1) : "\<C-f>"
|
|||
|
nnoremap <nowait><expr> <C-b> coc#float#has_scroll() ? coc#float#scroll(0) : "\<C-b>"
|
|||
|
inoremap <nowait><expr> <C-f> coc#float#has_scroll() ? "\<c-r>=coc#float#scroll(1)\<cr>" : "\<Right>"
|
|||
|
inoremap <nowait><expr> <C-b> coc#float#has_scroll() ? "\<c-r>=coc#float#scroll(0)\<cr>" : "\<Left>"
|
|||
|
|
|||
|
" Use CTRL-S for selections ranges.
|
|||
|
" Requires 'textDocument/selectionRange' support of language server.
|
|||
|
nmap <silent> <C-s> <Plug>(coc-range-select)
|
|||
|
xmap <silent> <C-s> <Plug>(coc-range-select)
|
|||
|
|
|||
|
" Add `:Format` command to format current buffer.
|
|||
|
command! -nargs=0 Format :call CocAction('format')
|
|||
|
|
|||
|
" Add `:Fold` command to fold current buffer.
|
|||
|
command! -nargs=? Fold :call CocAction('fold', <f-args>)
|
|||
|
|
|||
|
" Add `:OR` command for organize imports of the current buffer.
|
|||
|
command! -nargs=0 OR :call CocAction('runCommand', 'editor.action.organizeImport')
|
|||
|
|
|||
|
" Add (Neo)Vim's native statusline support.
|
|||
|
" NOTE: Please see `:h coc-status` for integrations with external plugins that
|
|||
|
" provide custom statusline: lightline.vim, vim-airline.
|
|||
|
set statusline^=%{coc#status()}%{get(b:,'coc_current_function','')}
|
|||
|
|
|||
|
" Mappings for CoCList
|
|||
|
" Show all diagnostics.
|
|||
|
nnoremap <silent><nowait> <space>a :<C-u>CocList diagnostics<cr>
|
|||
|
" Manage extensions.
|
|||
|
nnoremap <silent><nowait> <space>e :<C-u>CocList extensions<cr>
|
|||
|
" Show commands.
|
|||
|
nnoremap <silent><nowait> <space>c :<C-u>CocList commands<cr>
|
|||
|
" Find symbol of current document.
|
|||
|
nnoremap <silent><nowait> <space>o :<C-u>CocList outline<cr>
|
|||
|
" Search workspace symbols.
|
|||
|
nnoremap <silent><nowait> <space>s :<C-u>CocList -I symbols<cr>
|
|||
|
" Do default action for next item.
|
|||
|
nnoremap <silent><nowait> <space>j :<C-u>CocNext<CR>
|
|||
|
" Do default action for previous item.
|
|||
|
nnoremap <silent><nowait> <space>k :<C-u>CocPrev<CR>
|
|||
|
" Resume latest coc list.
|
|||
|
nnoremap <silent><nowait> <space>p :<C-u>CocListResume<CR>
|
|||
|
```
|
|||
|
|
|||
|
## Articles
|
|||
|
|
|||
|
- [coc.nvim 插件体系介绍](https://zhuanlan.zhihu.com/p/65524706)
|
|||
|
- [CocList 入坑指南](https://zhuanlan.zhihu.com/p/71846145)
|
|||
|
- [Create coc.nvim extension to improve Vim experience](https://medium.com/@chemzqm/create-coc-nvim-extension-to-improve-vim-experience-4461df269173)
|
|||
|
- [How to write a coc.nvim extension (and why)](https://samroeca.com/coc-plugin.html)
|
|||
|
|
|||
|
## Trouble shooting
|
|||
|
|
|||
|
Try these steps when you have problem with coc.nvim.
|
|||
|
|
|||
|
- Make sure your Vim version >= 8.0 by command `:version`.
|
|||
|
- If service failed to start, use command `:CocInfo` or `:checkhealth` on Neovim.
|
|||
|
- Checkout the log of coc.nvim by command `:CocOpenLog`.
|
|||
|
- When you have issues with the language server, it's recommended to [checkout
|
|||
|
the output](https://github.com/neoclide/coc.nvim/wiki/Debug-language-server#using-output-channel).
|
|||
|
|
|||
|
## Feedback
|
|||
|
|
|||
|
- If you think Coc is useful, consider giving it a star.
|
|||
|
- If you have a question, [ask on gitter](https://gitter.im/neoclide/coc.nvim)
|
|||
|
- 中文用户请到 [中文 gitter](https://gitter.im/neoclide/coc-cn) 讨论
|
|||
|
- If something is not working, [create an
|
|||
|
issue](https://github.com/neoclide/coc.nvim/issues/new).
|
|||
|
|
|||
|
<img src="https://user-images.githubusercontent.com/251450/57566955-fb850200-7404-11e9-960f-711673f1a461.png" width="593" height="574">
|
|||
|
|
|||
|
## License
|
|||
|
|
|||
|
MIT
|