" Primarly taken from: " https://github.com/neoclide/coc.nvim/tree/v0.0.82#example-vim-configuration " Abort if CoC is not loaded if !exists('g:did_coc_loaded') finish endif " Some servers have issues with backup files, see #649. set nobackup set nowritebackup " Always show the signcolumn, otherwise it would shift the text each time " diagnostics appear/become resolved. set signcolumn=yes "Use and for navigate completion list like built in completion. inoremap coc#pum#visible() ? coc#pum#next(1) : "\" inoremap coc#pum#visible() ? coc#pum#prev(1) : "\" " When no item was inserted yet, the first tab should insert the first item. " `timer_start` is used to delay the execution to insert in the real buffer as " far as I understand, otherwise vim will complain with 'E565: Not allowed to " change text or change window'. It is the same method used by coc.nvim (e.g. in " coc#pum#next). function! CocPumNext(n) if coc#pum#info()['inserted'] return coc#pum#next(a:n) else call timer_start(10, { -> coc#pum#select(0,1,0) }) return "\" endif endfunction " When no item was inserted yet, the first shift-tab should select and insert " the last item. See note about timer_start above. function! CocPumPrev(n) let l:info = coc#pum#info() if l:info['inserted'] return coc#pum#prev(a:n) else call timer_start(10, { -> coc#pum#select(l:info['size'] - 1,1,0) }) return "\" endif endfunction " Returns true if the cursor is at the beginning of the line or behind " whitespace. function! CheckBackspace() abort let col = col('.') - 1 return !col || getline('.')[col - 1] =~# '\s' endfunction " Use tab for trigger completion with characters ahead and navigate. " NOTE: Use command ':verbose imap ' to make sure tab is not mapped by " other plugin before putting this into your config. inoremap \ coc#pum#visible() ? CocPumNext(1) : \ CheckBackspace() ? "\" : \ coc#refresh() inoremap coc#pum#visible() ? CocPumPrev(1) : "\" " Use to trigger completion. if has('nvim') inoremap coc#refresh() else inoremap coc#refresh() endif " Make to accept selected completion item or notify coc.nvim to format " u starts a new undo break, please make your own choice. inoremap coc#pum#visible() ? coc#pum#confirm() \: "\u\\=coc#on_enter()\" " Use `[g` and `]g` to navigate diagnostics " Use `:CocDiagnostics` to get all diagnostics of current buffer in location list. nmap [g (coc-diagnostic-prev) nmap ]g (coc-diagnostic-next) " GoTo code navigation. nmap gd (coc-definition) nmap gy (coc-type-definition) nmap gi (coc-implementation) nmap gr (coc-references) " Use K to show documentation in preview window. nnoremap K :call ShowDocumentation() function! ShowDocumentation() if CocAction('hasProvider', 'hover') call CocActionAsync('doHover') else call feedkeys('K', 'in') endif endfunction " Highlight the symbol and its references when holding the cursor. autocmd CursorHold * silent call CocActionAsync('highlight') " Symbol renaming. nmap rn (coc-rename) " Formatting selected code. " xmap f (coc-format-selected) " nmap f (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: `aap` for current paragraph xmap a (coc-codeaction-selected) nmap a (coc-codeaction-selected) " Remap keys for applying codeAction to the current buffer. nmap ac (coc-codeaction) " Apply AutoFix to problem on the current line. nmap qf (coc-fix-current) " Run the Code Lens action on the current line. nmap rcl (coc-codelens-action) " Map function and class text objects " NOTE: Requires 'textDocument.documentSymbol' support from the language server. xmap if (coc-funcobj-i) omap if (coc-funcobj-i) xmap af (coc-funcobj-a) omap af (coc-funcobj-a) xmap io (coc-classobj-i) omap io (coc-classobj-i) xmap ao (coc-classobj-a) omap ao (coc-classobj-a) " Remap and for scroll float windows/popups. if has('nvim-0.4.0') || has('patch-8.2.0750') nnoremap coc#float#has_scroll() ? coc#float#scroll(1) : "\" nnoremap coc#float#has_scroll() ? coc#float#scroll(0) : "\" inoremap coc#float#has_scroll() ? "\=coc#float#scroll(1)\" : "\" inoremap coc#float#has_scroll() ? "\=coc#float#scroll(0)\" : "\" vnoremap coc#float#has_scroll() ? coc#float#scroll(1) : "\" vnoremap coc#float#has_scroll() ? coc#float#scroll(0) : "\" endif " Use CTRL-S for selections ranges. " Requires 'textDocument/selectionRange' support of language server. nmap (coc-range-select) xmap (coc-range-select) " Add `:Format` command to format current buffer. command! -nargs=0 Format :call CocActionAsync('format') " Add `:Fold` command to fold current buffer. command! -nargs=? Fold :call CocAction('fold', ) " Add `:OR` command for organize imports of the current buffer. command! -nargs=0 OR :call CocActionAsync('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=%f\ %y%h%w%m%r%= set statusline+=%{coc#status()}%{get(b:,'coc_current_function','')} set statusline+=\ \ %l,%c%V\ %P " Mappings for CoCList disabled but kept here for look up reference. " " Show all diagnostics. " nnoremap a :CocList diagnostics " " Manage extensions. " nnoremap e :CocList extensions " " Show commands. " nnoremap c :CocList commands " " Find symbol of current document. " nnoremap o :CocList outline " " Search workspace symbols. " nnoremap s :CocList -I symbols " " Do default action for next item. " nnoremap j :CocNext " " Do default action for previous item. " nnoremap k :CocPrev " " Resume latest coc list. " nnoremap p :CocListResume