summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
Diffstat (limited to 'modules')
-rw-r--r--modules/coc.vim144
-rw-r--r--modules/nodepath.vim2
-rw-r--r--modules/plugins.vim8
-rw-r--r--modules/vim-which-key.vim1
4 files changed, 152 insertions, 3 deletions
diff --git a/modules/coc.vim b/modules/coc.vim
new file mode 100644
index 00000000..855127a0
--- /dev/null
+++ b/modules/coc.vim
@@ -0,0 +1,144 @@
+" 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.
+set signcolumn=yes
+
+"better nav for omnicomplete
+inoremap <expr> <c-j> ("\<C-n>")
+inoremap <expr> <c-k> ("\<C-p>")
+
+" 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.
+inoremap <silent><expr> <c-space> coc#refresh()
+
+" Use <cr> to confirm completion, `<C-g>u` means break undo chain at current
+" position. Coc only does snippet and additional edit on confirm.
+if has('patch8.1.1068')
+ " Use `complete_info` if your (Neo)Vim version supports it.
+ inoremap <expr> <cr> complete_info()["selected"] != "-1" ? "\<C-y>" : "\<C-g>u\<CR>"
+else
+ imap <expr> <cr> pumvisible() ? "\<C-y>" : "\<C-g>u\<CR>"
+endif
+
+" Use `[g` and `]g` to navigate diagnostics
+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>')
+ else
+ call CocAction('doHover')
+ 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 line.
+nmap <leader>ac <Plug>(coc-codeaction)
+" Apply AutoFix to problem on the current line.
+nmap <leader>qf <Plug>(coc-fix-current)
+
+" Introduce function text object
+" NOTE: Requires 'textDocument.documentSymbol' support from the language server.
+xmap if <Plug>(coc-funcobj-i)
+xmap af <Plug>(coc-funcobj-a)
+omap if <Plug>(coc-funcobj-i)
+omap af <Plug>(coc-funcobj-a)
+
+" Use <TAB> for selections ranges.
+" NOTE: Requires 'textDocument/selectionRange' support from the language server.
+" coc-tsserver, coc-python are the examples of servers that support it.
+nmap <silent> <TAB> <Plug>(coc-range-select)
+xmap <silent> <TAB> <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 using CoCList:
+" Show all diagnostics.
+nnoremap <silent> <space>a :<C-u>CocList diagnostics<cr>
+" Manage extensions.
+nnoremap <silent> <space>e :<C-u>CocList extensions<cr>
+" Show commands.
+nnoremap <silent> <space>c :<C-u>CocList commands<cr>
+" Find symbol of current document.
+nnoremap <silent> <space>o :<C-u>CocList outline<cr>
+" Search workspace symbols.
+nnoremap <silent> <space>s :<C-u>CocList -I symbols<cr>
+" Do default action for next item.
+nnoremap <silent> <space>j :<C-u>CocNext<CR>
+" Do default action for previous item.
+nnoremap <silent> <space>k :<C-u>CocPrev<CR>
+" Resume latest coc list.
+nnoremap <silent> <space>p :<C-u>CocListResume<CR>
diff --git a/modules/nodepath.vim b/modules/nodepath.vim
new file mode 100644
index 00000000..20d6c33d
--- /dev/null
+++ b/modules/nodepath.vim
@@ -0,0 +1,2 @@
+" You can comment this and recomment it after installing coc executable('~/.nvm/versions/node/v12.16.1/bin/node')
+let g:coc_node_path = expand("~/.nvm/versions/node/v12.16.1/bin/node")
diff --git a/modules/plugins.vim b/modules/plugins.vim
index 47117172..2538b601 100644
--- a/modules/plugins.vim
+++ b/modules/plugins.vim
@@ -12,6 +12,8 @@ if dein#load_state('~/.config/nvim/dein')
"call dein#add('kevinhwang91/rnvimr', {'do': 'make sync'})
call dein#add('francoiscabrol/ranger.vim')
call dein#add('rbgrouleff/bclose.vim')
+ " Language support
+ call dein#add('neoclide/coc.nvim', {'merged':0, 'rev': 'release'})
" All the Themes
call dein#add('joshdick/onedark.vim')
" key menu popup "
@@ -48,7 +50,7 @@ if dein#load_state('~/.config/nvim/dein')
" Buffergator use \b
"" call dein#add('jeetsukumaran/vim-buffergator')
" Ctrlp
- call dein#add('ctrlpvim/ctrlp.vim')
+ "call dein#add('ctrlpvim/ctrlp.vim')
"Linting
call dein#add('w0rp/ale')
call dein#add('autozimu/LanguageClient-neovim', {
@@ -56,8 +58,8 @@ if dein#load_state('~/.config/nvim/dein')
\ 'build': 'bash install.sh',
\ })
" Fuzzy finder
- call dein#add('junegunn/fzf.vim', { 'dir': '~/.fzf', 'do': './install --all' })
- call dein#add('junegunn/fzf')
+ "call dein#add('junegunn/fzf.vim', { 'dir': '~/.fzf', 'do': './install --all' })
+ "call dein#add('junegunn/fzf')
" Sneak mode "
call dein#add('justinmk/vim-sneak')
""Git
diff --git a/modules/vim-which-key.vim b/modules/vim-which-key.vim
index 1931a42e..2e791a06 100644
--- a/modules/vim-which-key.vim
+++ b/modules/vim-which-key.vim
@@ -32,6 +32,7 @@ nnoremap <silent> <leader>code :call OpenConfigFile('~/Library/Application Suppo
let g:which_key_map['/'] = [ '<Plug>NERDCommenterToggle','commenter' ]
let g:which_key_map['p'] = [ 'pclose','close-preview' ]
let g:which_key_map['q'] = [ 'q','quit' ]
+let g:which_key_map['d'] = [ 'bd','delete-buffer' ]
let g:which_key_map['s'] = [ 'w','save' ]
"let g:which_key_map['f'] = [ 'Denite file','files' ]
let g:which_key_map['f'] = [ 'Ranger','Ranger' ]