From 907dd57c9213ad3b2b5b5ee0b30d624eb0464117 Mon Sep 17 00:00:00 2001 From: Paul Walker Date: Tue, 28 Jan 2020 22:15:59 +0000 Subject: [PATCH] vim: add coc, svelte, mustache --- vimrc | 169 +++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 156 insertions(+), 13 deletions(-) diff --git a/vimrc b/vimrc index a329a60..14fdb76 100644 --- a/vimrc +++ b/vimrc @@ -27,6 +27,7 @@ call plug#begin('~/.vim/plugged') " you to cd ~/.vim/plugged/YouCompleteMe " python ./install.py --js-completer " Plug 'Valloric/YouCompleteMe' + Plug 'neoclide/coc.nvim', {'branch': 'release'} Plug 'dense-analysis/ale' Plug 'tpope/vim-commentary' @@ -37,6 +38,8 @@ call plug#begin('~/.vim/plugged') Plug 'othree/html5.vim' Plug 'matthew-brett/vim-rst-sections' Plug 'cespare/vim-toml' + Plug 'mustache/vim-mustache-handlebars' + Plug 'evanleck/vim-svelte' Plug 'elixir-editors/vim-elixir' Plug 'elzr/vim-json' @@ -56,12 +59,15 @@ endif set backupdir=/tmp//,. set directory=/tmp//,. -if v:version >= 703 - set backupdir=/tmp//,. -endif -" TODO put in file groups -" imap cll console.log()==f(a +" Make the current word upper-case; useful for constants. +nnoremap wu viwU +nnoremap wl viwu +nnoremap viwU +nnoremap viwu + +nmap cw y/ +nmap wp 0v$gq augroup filetype_elixir autocmd! @@ -117,14 +123,14 @@ map :pop " tabbing and indent options function! TabSize (size) - if a:size==8 - set noexpandtab - else - set expandtab - endif - exe 'set shiftwidth=' . a:size - exe 'set tabstop=' . a:size - return "Tab size = " . a:size + if a:size==8 + set noexpandtab + else + set expandtab + endif + exe 'set shiftwidth=' . a:size + exe 'set tabstop=' . a:size + return "Tab size = " . a:size endfunction call TabSize(2) map ,t2 :echo TabSize(2) @@ -132,6 +138,10 @@ map ,t3 :echo TabSize(3) map ,t4 :echo TabSize(4) map ,t8 :echo TabSize(8) +augroup filetype_python + call TabSize(2) +augroup END + " treat C preprocessed assembler files as C augroup filetype au! @@ -199,6 +209,8 @@ nnoremap wfw :set winfixwidth " Fix the height of the window nnoremap wfh :set winfixheight +nnoremap qw /\si"?\si" + " map :wincmd k " map :wincmd j @@ -409,4 +421,135 @@ function! ToggleWindowHorizontalVerticalSplit() endfunction nnoremap wst :call ToggleWindowHorizontalVerticalSplit() +inoremap / ==gi +" 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\" +" Or use `complete_info` if your vim support it, like: +" inoremap complete_info()["selected"] != "-1" ? "\" : "\u\" + +" Use `[g` and `]g` to navigate diagnostics +nmap [g (coc-diagnostic-prev) +nmap ]g (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) + +" Create mappings for function text object, requires document symbols feature of languageserver. +xmap if (coc-funcobj-i) +xmap af (coc-funcobj-a) +omap if (coc-funcobj-i) +omap af (coc-funcobj-a) + +" Use for select selections ranges, needs server support, like: coc-tsserver, coc-python +nmap (coc-range-select) +xmap (coc-range-select) + +" 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 + +nmap :>