From b646832f5b6e5e5874f8751d2154941bbaeb458d Mon Sep 17 00:00:00 2001 From: Robert Kmiec Date: Wed, 26 May 2021 00:58:29 +0200 Subject: [PATCH] nvim: initial configuration, mostly copied from vim --- .config/nvim/init.vim | 306 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 306 insertions(+) create mode 100644 .config/nvim/init.vim diff --git a/.config/nvim/init.vim b/.config/nvim/init.vim new file mode 100644 index 0000000..84ddfea --- /dev/null +++ b/.config/nvim/init.vim @@ -0,0 +1,306 @@ +let plug_install = 0 +let autoload_plug_path = stdpath('config') . '/autoload/plug.vim' + +if !filereadable(autoload_plug_path) + silent exe '!curl -fL --create-dirs -o ' . autoload_plug_path . + \ ' https://raw.github.com/junegunn/vim-plug/master/plug.vim' + execute 'source ' . fnameescape(autoload_plug_path) + let plug_install = 1 +endif +unlet autoload_plug_path + +call plug#begin('~/.config/nvim/plugins') + +" Code development helpers {{{ +Plug 'neoclide/coc.nvim', {'branch': 'release'} | Plug 'jackguo380/vim-lsp-cxx-highlight' +Plug 'SirVer/ultisnips' | Plug 'honza/vim-snippets' +Plug 'wellle/context.vim' +Plug 'dbeniamine/cheat.sh-vim' +" }}} + +" Files switch, jump and grep-like tools {{{ +Plug 'preservim/nerdtree' | Plug 'Xuyuanp/nerdtree-git-plugin' +Plug 'junegunn/fzf.vim' +Plug 'liuchengxu/vista.vim' +Plug 'inside/vim-search-pulse' +Plug 'mhinz/vim-startify' +" }}} + +" Git integration {{{ +Plug 'mhinz/vim-signify' " Mark edited lines - faster gitgutter +" }}} + +" Colorschemes {{{ +Plug 'jaredgorski/spacecamp' +Plug 'vim-airline/vim-airline' | Plug 'vim-airline/vim-airline-themes' +" }}} + +" Other plugins (external tools, etc) {{{ +Plug 'junegunn/goyo.vim' +Plug 'jez/vim-superman' "vman application +Plug 'glacambre/firenvim' +" }}} + +call plug#end() + +if plug_install + PlugInstall --sync +endif +unlet plug_install + +set number +set clipboard+=unnamedplus + +set noshowmode +set laststatus=2 + +set background=dark +colorscheme spacecamp +highlight MatchParen ctermfg=yellow ctermbg=none cterm=NONE +set listchars=tab:▸\ ,trail:¬ +set list +hi clear SpellBad +hi SpellBad cterm=underline + + +set tabstop=4 +set shiftwidth=4 +set softtabstop=4 +set expandtab + +" Ctags {{{ +if isdirectory($HOME . '/.vim/tags') == 0 + :silent !mkdir -p ~/.vim/tags > /dev/null 2>&1 +endif +let g:gutentags_cache_dir='~/.vim/tags' +"let g:gutentags_ctags_extra_args=['--fields=+l'] + +let mapleader = "\\" + +inoremap jj +inoremap jk +inoremap :w :w + +nnoremap 2 :set tabstop=2 softtabstop=2 shiftwidth=2 +nnoremap 4 :set tabstop=4 softtabstop=4 shiftwidth=4 +nnoremap 8 :set tabstop=8 softtabstop=8 shiftwidth=8 + +nnoremap :nohlsearch + +let g:UltiSnipsExpandTrigger="" +let g:UltiSnipsJumpForwardTrigger="" +let g:UltiSnipsJumpBackwardTrigger="" + +" 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. +if has("patch-8.1.1564") + " Recently vim can merge signcolumn and number column into one + set signcolumn=number +else + set signcolumn=yes +endif + +" 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) +" Apply AutoFix to problem on the current line. +nmap qf (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 + +" yoink configuration +"nmap yp (YoinkPostPasteSwapBack) +"nmap yn (YoinkPostPasteSwapForward) +"nmap p (YoinkPaste_p) +"nmap P (YoinkPaste_P) + +" Mapping to NERDTree +nnoremap t :NERDTreeToggle +let NERDTreeIgnore=['\.vim$', '\~$', '\.pyc$'] + +nnoremap ff :FZF! +nnoremap fl :Lines! +nnoremap fb :Buffers +inoremap fs :Snippets! +nnoremap fa :Rg! + +" Disable context.vim on json files +let g:context_filetype_blacklist = ["json"] + +match Error /\s\+$\|DU\cPA/ + +function! FindAlternate() + let l:ext = 'h' + let l:curr_ext = expand('%:e') + if (l:curr_ext == 'c') + let l:ext = 'h' + elseif (l:curr_ext == 'cpp') + let l:ext = 'h' + elseif (l:curr_ext == 'h') + let l:ext = 'c' + elseif (l:curr_ext == 'hpp') + let l:ext = 'cpp' + endif + let l:file = expand('%:t:r') . '.' . l:ext + :exec 'find ' . l:file +endfunction + +nnoremap :call FindAlternate() + +setglobal virtualedit=block +setglobal shiftround + +let g:vim_search_pulse_mode = 'pattern' +let g:vim_search_pulse_duration = 400 + +let g:airline_theme = 'minimalist' +let g:airline_powerline_fonts = 1 +let g:airline_stl_path_style = 'short' +let g:airline_highlighting_cache = 1 + +let g:startify_custom_header = ''