From b33daab7f88a219e34f0f85d5ffe4ec1374e15e2 Mon Sep 17 00:00:00 2001 From: Garrit Franke Date: Thu, 27 May 2021 07:53:59 +0200 Subject: [PATCH] feat(vim): add comfy IDE bindings --- .config/nvim/init.vim | 215 +++++++++++++++++++++++++++++++++--------- README.md | 1 + 2 files changed, 174 insertions(+), 42 deletions(-) create mode 100644 README.md diff --git a/.config/nvim/init.vim b/.config/nvim/init.vim index 6745c49..3b9a28f 100644 --- a/.config/nvim/init.vim +++ b/.config/nvim/init.vim @@ -16,7 +16,6 @@ Plug 'scrooloose/nerdtree' Plug 'prettier/vim-prettier' Plug 'tpope/vim-fugitive' Plug 'airblade/vim-gitgutter' -Plug 'lifepillar/vim-mucomplete' Plug 'pangloss/vim-javascript' Plug 'mxw/vim-jsx' @@ -29,8 +28,7 @@ Plug 'justinmk/vim-sneak' " HTML auto completion Plug 'alvan/vim-closetag' - -Plug 'w0rp/ale' +Plug 'neoclide/coc.nvim', {'branch': 'release'} " Antimony syntax highlighting Plug 'antimony-lang/antimony.vim' @@ -43,8 +41,10 @@ colorscheme gruvbox let mapleader=" " " Set leader key syntax on " Enable syntax highlighting call matchadd('ColorColumn', '\%81v', 100) " Show a column after 80 chars + set number relativenumber " Show line numbers in relative manner set mouse=a " Enable mouse +set updatetime=300 " Quicker update time means snappier feedback set mousemodel=popup_setpos set tabstop=4 softtabstop=4 set shiftwidth=4 @@ -53,6 +53,10 @@ set expandtab set backspace=indent,eol,start set showmatch set noswapfile +set nobackup +set nowritebackup +set shortmess+=c " Don't pass messages to |ins-completion-menu|. +set cmdheight=2 " Give more space for displaying messages. set ignorecase set scrolloff=8 set hidden @@ -64,7 +68,6 @@ set nohlsearch " when running at every change you may want to disable quickfix let g:prettier#quickfix_enabled = 0 let g:prettier#autoformat = 0 -autocmd BufWritePre,TextChanged,InsertLeave *.js,*.css,*.scss,*.less PrettierAsync "completion settings: set completeopt+=menuone @@ -74,30 +77,157 @@ set shortmess+=c " Shut off completion messages set belloff+=ctrlg " If Vim beeps during completion let g:mucomplete#enable_auto_at_startup = 1 +" Always show the signcolumn, otherwise it would shift the text each time +" diagnostics appear/become resolved. +if has("nvim-0.5.0") || has("patch-8.1.1564") + " Recently vim can merge signcolumn and number column into one + set signcolumn=number +else + set signcolumn=yes +endif + +" COC + +" 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 + \ 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. +if has('nvim') + inoremap coc#refresh() +else + inoremap coc#refresh() +endif + +" Make auto-select the first completion item and notify coc.nvim to +" format on enter, could be remapped by other vim plugin +inoremap pumvisible() ? coc#_select_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 show_documentation() + +function! s:show_documentation() + if (index(['vim','help'], &filetype) >= 0) + execute 'h '.expand('') + elseif (coc#rpc#ready()) + call CocActionAsync('doHover') + else + execute '!' . &keywordprg . " " . expand('') + 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) +nmap (coc-codeaction) +" Apply AutoFix to problem on the current line. +nmap f (coc-fix-current) + +" 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 ic (coc-classobj-i) +omap ic (coc-classobj-i) +xmap ac (coc-classobj-a) +omap ac (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 CocAction('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 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 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 + " FZF -let $FZF_DEFAULT_COMMAND = 'ag --hidden --ignore .git -l -g ""' - -"Vim A.L.E - "Enable A.L.E -let g:ale_completion_enabled = 1 -let g:ale_sign_error = "✗" -let g:ale_sign_warning = "⚠" - -"A.L.E Rust Settings -"Various settings for Rust -let g:ale_linters = {'rust': ['rls']} -let b:ale_fixers = {'javascript': ['prettier', 'eslint'], 'rust': ['rustfmt'], 'php': ['php_cs_fixer']} - -let g:ale_fixers = { -\ '*': ['remove_trailing_lines', 'trim_whitespace'], -\ 'javascript': ['prettier', 'eslint'], -\ 'rust': ['rustfmt'], -\ 'php': ['php_cs_fixer'] -\} - -let g:ale_rust_rls_executable = '~/.cargo/bin/rls' -let g:ale_rust_rls_toolchain = 'stable' -" let g:ale_fix_on_save = 0 + +let $FZF_DEFAULT_COMMAND = 'rg --files --hidden --follow --no-ignore-vcs' " NerdTree @@ -118,20 +248,17 @@ autocmd VimEnter * if argc() == 1 && isdirectory(argv()[0]) && !exists('s:std_in \ execute 'NERDTree' argv()[0] | wincmd p | enew | execute 'cd '.argv()[0] | endif " Mirror the NERDTree before showing it. This makes it the same on all tabs. -nnoremap :NERDTreeMirror:NERDTreeFocus +nnoremap :NERDTreeMirror:NERDTreeFind " ----------------------- " Remaps " ----------------------- - -:autocmd BufWritePost * ALEFix - " Leader Remaps nnoremap :tabn +nnoremap :tabn nnoremap :tabp -nnoremap gd :ALEGoToDefinition -nnoremap f :ALEFix +nnoremap :tabp nnoremap k gk nnoremap j gj @@ -140,13 +267,13 @@ nnoremap j gj nnoremap :NERDTreeToggle nnoremap :NERDTreeFind -" ctrl up/down (Move lines) -nnoremap :m .+1== -nnoremap :m .-2== -inoremap :m .+1==gi -inoremap :m .-2==gi -vnoremap :m '>+1gv=gv -vnoremap :m '<-2gv=gv +" ctrl alt up/down (Move lines) +nnoremap :m .+1== +nnoremap :m .-2== +inoremap :m .+1==gi +inoremap :m .-2==gi +vnoremap :m '>+1gv=gv +vnoremap :m '<-2gv=gv " ctrl shift f (Find in directory) nnoremap :Rg @@ -158,5 +285,9 @@ nnoremap :Files " Use yank to copy to clipboard vnoremap y "*y -" ctrl w (close tab) -nnoremap :tabclose +" ctrl q (close tab) +nnoremap :tabclose + +" ctrl alt h/l (switch tabs) +nnoremap :tabprevious +nnoremap :tabnext diff --git a/README.md b/README.md new file mode 100644 index 0000000..62ac67e --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +# Dotfiles