From 7f1ae75e299d60fdf4a96fe89e80ef953fc711b8 Mon Sep 17 00:00:00 2001 From: Marcel Schneider Date: Tue, 10 Sep 2019 15:32:48 +0200 Subject: [PATCH] substitue old deoplete plugins with coc --- init.vim | 156 +++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 123 insertions(+), 33 deletions(-) diff --git a/init.vim b/init.vim index 66809ca..73a9e15 100644 --- a/init.vim +++ b/init.vim @@ -18,7 +18,7 @@ Plug 'tpope/vim-dispatch' " Needed for dadbod Plug 'scrooloose/nerdtree', { 'on': 'NERDTreeToggle' } " file tree Plug 'Xuyuanp/nerdtree-git-plugin', { 'on': 'NERDTreeToggle' } Plug 'scrooloose/nerdcommenter' " better commenting -Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' } " completion engine +Plug 'neoclide/coc.nvim', {'branch': 'release'} " coc - completion Plug 'Shougo/neosnippet.vim' " snippet engine Plug 'Shougo/neosnippet-snippets' " snippets Plug 'easymotion/vim-easymotion' " better motion with leader @@ -48,12 +48,10 @@ Plug 'moll/vim-node', { 'for': [ 'javascript', 'vue' ]} " node support Plug 'https://github.com/othree/jspc.vim', { 'for': [ 'javascript', 'vue' ]} " Function parameter completion Plug 'heavenshell/vim-jsdoc', { 'for': [ 'javascript', 'vue' ]} " Generate JSDoc comments Plug 'posva/vim-vue', { 'for': [ 'javascript', 'html', 'vue' ] } " vue.js integration -Plug 'carlitux/deoplete-ternjs', { 'for': [ 'javascript', 'vue', 'html' ], 'do': 'npm install -g tern' } " deoplete completion via ternjs "}}} " Go {{{ Plug 'fatih/vim-go', { 'for': [ 'go', 'html', 'gohtmltmpl' ], 'do': ':GoInstallBinaries' } " go support -Plug 'zchee/deoplete-go', { 'for': 'go' } "}}} " LaTeX{{{ @@ -85,10 +83,6 @@ Plug 'rhysd/vim-clang-format', { 'for' : ['c', 'cpp', 'java'] } "}}} " PHP{{{ -"Plug 'shawncplus/phpcomplete.vim', { 'for': 'php', 'do': 'curl -Ss http://vim-php.com/phpctags/install/phpctags.phar > ~/bin/phpctags && chmod +x ~/bin/phpctags' } -"Plug 'lvht/phpcd.vim', { 'for': 'php', 'do': 'composer install' } -Plug 'phpactor/phpactor', {'for': 'php', 'do': 'composer install'} -Plug 'kristijanhusak/deoplete-phpactor', { 'for': 'php' } Plug 'captbaritone/better-indent-support-for-php-with-html', { 'for': 'php' } Plug 'lumiliet/vim-twig', { 'for': [ 'php', 'html' ] } " Twig templates Plug 'Rican7/php-doc-modded', { 'for': 'php' } " Automatic phpdoc comments @@ -108,10 +102,6 @@ Plug 'artur-shaik/vim-javacomplete2', { 'for': 'java' } Plug 'vim-scripts/mips.vim' "}}} -" Rust {{{ -Plug 'sebastianmarkow/deoplete-rust', {'for': 'rust' } -"}}} - " All of your Plugins must be added before the following line call plug#end() " required filetype plugin indent on " required @@ -257,28 +247,128 @@ autocmd FileType c,cpp,objc vnoremap f :ClangFormat "}}} " Completion {{{ -" Use deoplete. -let g:deoplete#enable_at_startup = 1 - -" Use TAB to cycle between matches -inoremap pumvisible() ? "\" : "\" -inoremap pumvisible() ? "\" : "\" - -let g:deoplete#ignore_sources = get(g:, 'deoplete#ignore_sources', {}) -let g:deoplete#ignore_sources.php = ['omni'] - -" Neosnippet Settings -imap (neosnippet_expand_or_jump) -smap (neosnippet_expand_or_jump) -xmap (neosnippet_expand_target) - -" SuperTab like snippets behavior. -"imap -" \ pumvisible() ? "\" : -" \ neosnippet#expandable_or_jumpable() ? -" \ "\(neosnippet_expand_or_jump)" : "\" -smap neosnippet#expandable_or_jumpable() ? - \ "\(neosnippet_expand_or_jump)" : "\" + +" if hidden is not set, TextEdit might fail. +set hidden + +" Some servers have issues with backup files, see #649 +set nobackup +set nowritebackup + +" Better display for messages +set cmdheight=2 + +" You will have bad experience for diagnostic messages when it's default 4000. +set updatetime=300 + +" don't give |ins-completion-menu| messages. +set shortmess+=c + +" always show signcolumns +set signcolumn=yes + +" Use tab for trigger completion with characters ahead and navigate. +" Use command ':verbose imap ' to make sure tab is not mapped by other plugin. +inoremap + \ pumvisible() ? "\" : + \ check_back_space() ? "\" : + \ coc#refresh() +inoremap pumvisible() ? "\" : "\" + +function! s:check_back_space() abort + let col = col('.') - 1 + return !col || getline('.')[col - 1] =~# '\s' +endfunction + +" Use to trigger completion. +inoremap coc#refresh() + +" Use to confirm completion, `u` means break undo chain at current position. +" Coc only does snippet and additional edit on confirm. +inoremap pumvisible() ? "\" : "\u\" + +" Use `[c` and `]c` to navigate diagnostics +nmap [c (coc-diagnostic-prev) +nmap ]c (coc-diagnostic-next) + +" Remap keys for gotos +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 show_documentation() + +function! s:show_documentation() + if (index(['vim','help'], &filetype) >= 0) + execute 'h '.expand('') + else + call CocAction('doHover') + endif +endfunction + +" Highlight symbol under cursor on CursorHold +autocmd CursorHold * silent call CocActionAsync('highlight') + +" Remap for rename current word +nmap rn (coc-rename) + +" Remap for format selected region +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 + +" Remap for do codeAction of selected region, ex: `aap` for current paragraph +xmap a (coc-codeaction-selected) +nmap a (coc-codeaction-selected) + +" Remap for do codeAction of current line +nmap ac (coc-codeaction) +" Fix autofix problem of current line +nmap qf (coc-fix-current) + +" Use for select selections ranges, needs server support, like: coc-tsserver, coc-python +nmap (coc-range-select) +xmap (coc-range-select) +xmap (coc-range-select-backword) + +" Use `:Format` to format current buffer +command! -nargs=0 Format :call CocAction('format') + +" Use `:Fold` to fold current buffer +command! -nargs=? Fold :call CocAction('fold', ) + +" use `:OR` for organize import of current buffer +command! -nargs=0 OR :call CocAction('runCommand', 'editor.action.organizeImport') + +" Add status line support, for integration with other plugin, checkout `:h coc-status` +set statusline^=%{coc#status()}%{get(b:,'coc_current_function','')} + +" Using CocList +" 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: " For conceal markers. if has('conceal')