From a29fa44b3a0bd6f726ab2e8169dec35b697b04a0 Mon Sep 17 00:00:00 2001 From: aktersnurra Date: Sun, 7 Feb 2021 20:35:46 +0100 Subject: neovim config added --- .config/nvim/plug-config/coc.vim | 200 ++++++++++++++++++++++++++++++ .config/nvim/plug-config/polyglot.vim | 7 ++ .config/nvim/plug-config/rnvimr.vim | 4 + .config/nvim/plug-config/signify.vim | 16 +++ .config/nvim/plug-config/sneak.vim | 25 ++++ .config/nvim/plug-config/start-screen.vim | 39 ++++++ 6 files changed, 291 insertions(+) create mode 100644 .config/nvim/plug-config/coc.vim create mode 100644 .config/nvim/plug-config/polyglot.vim create mode 100644 .config/nvim/plug-config/rnvimr.vim create mode 100644 .config/nvim/plug-config/signify.vim create mode 100644 .config/nvim/plug-config/sneak.vim create mode 100644 .config/nvim/plug-config/start-screen.vim (limited to '.config/nvim/plug-config') diff --git a/.config/nvim/plug-config/coc.vim b/.config/nvim/plug-config/coc.vim new file mode 100644 index 0000000..ec9af9f --- /dev/null +++ b/.config/nvim/plug-config/coc.vim @@ -0,0 +1,200 @@ +" 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#foat#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 :CocListResumel + +" Explorer +let g:coc_explorer_global_presets = { +\ '.vim': { +\ 'root-uri': '~/.vim', +\ }, +\ 'tab': { +\ 'position': 'tab', +\ 'quit-on-open': v:true, +\ }, +\ 'floating': { +\ 'position': 'floating', +\ 'open-action-strategy': 'sourceWindow', +\ }, +\ 'floatingTop': { +\ 'position': 'floating', +\ 'floating-position': 'center-top', +\ 'open-action-strategy': 'sourceWindow', +\ }, +\ 'floatingLeftside': { +\ 'position': 'floating', +\ 'floating-position': 'left-center', +\ 'floating-width': 50, +\ 'open-action-strategy': 'sourceWindow', +\ }, +\ 'floatingRightside': { +\ 'position': 'floating', +\ 'floating-position': 'right-center', +\ 'floating-width': 50, +\ 'open-action-strategy': 'sourceWindow', +\ }, +\ 'simplify': { +\ 'file-child-template': '[selection | clip | 1] [indent][icon | 1] [filename omitCenter 1]' +\ } +\ } + +nmap e :CocCommand explorer +nmap f :CocCommand explorer --preset floating +autocmd BufEnter * if (winnr("$") == 1 && &filetype == 'coc-explorer') | q | endif diff --git a/.config/nvim/plug-config/polyglot.vim b/.config/nvim/plug-config/polyglot.vim new file mode 100644 index 0000000..8c82247 --- /dev/null +++ b/.config/nvim/plug-config/polyglot.vim @@ -0,0 +1,7 @@ +let g:polyglot_disabled = ['csv'] + +let g:python_highlight_all=1 + +let g:vim_jsx_pretty_colorful_config = 1 + +set re=0 diff --git a/.config/nvim/plug-config/rnvimr.vim b/.config/nvim/plug-config/rnvimr.vim new file mode 100644 index 0000000..b5912b0 --- /dev/null +++ b/.config/nvim/plug-config/rnvimr.vim @@ -0,0 +1,4 @@ +" Make Ranger replace netrw and be the file explorer +let g:rnvimr_ex_enable = 1 + +nmap r :RnvimrToggle diff --git a/.config/nvim/plug-config/signify.vim b/.config/nvim/plug-config/signify.vim new file mode 100644 index 0000000..ad38e20 --- /dev/null +++ b/.config/nvim/plug-config/signify.vim @@ -0,0 +1,16 @@ +" Change these if you want +let g:signify_sign_add = '+' +let g:signify_sign_delete = '_' +let g:signify_sign_delete_first_line = '‾' +let g:signify_sign_change = '~' + +" I find the numbers disctracting +let g:signify_sign_show_count = 0 +let g:signify_sign_show_text = 1 + + +" Jump though hunks +nmap gj (signify-next-hunk) +nmap gk (signify-prev-hunk) +nmap gJ 9999gJ +nmap gK 9999gk diff --git a/.config/nvim/plug-config/sneak.vim b/.config/nvim/plug-config/sneak.vim new file mode 100644 index 0000000..2641dc9 --- /dev/null +++ b/.config/nvim/plug-config/sneak.vim @@ -0,0 +1,25 @@ +let g:sneak#label = 1 + +" case insensitive sneak +let g:sneak#use_ic_scs = 1 + +" immediately move to the next instance of search, if you move the cursor sneak is back to default behavior +let g:sneak#s_next = 1 + +" remap so I can use , and ; with f and t +map gS Sneak_, +map gs Sneak_; + +" Change the colors +highlight Sneak guifg=black guibg=#00C7DF ctermfg=black ctermbg=cyan +highlight SneakScope guifg=red guibg=yellow ctermfg=red ctermbg=yellow + +" Cool prompts +" let g:sneak#prompt = '🕵️' +let g:sneak#prompt = '🔎 ' + +" I like quickscope better for this since it keeps me in the scope of a single line +" map f Sneak_f +" map F Sneak_F +" map t Sneak_t +" map T Sneak_T diff --git a/.config/nvim/plug-config/start-screen.vim b/.config/nvim/plug-config/start-screen.vim new file mode 100644 index 0000000..ae39a8c --- /dev/null +++ b/.config/nvim/plug-config/start-screen.vim @@ -0,0 +1,39 @@ + +let g:startify_custom_header = [ + \ ' _ ___ ________ __ ', + \ ' / | / / | / / ____/___ ____/ /__ ', + \ ' / |/ /| | / / / / __ \/ __ / _ \', + \ ' / /| / | |/ / /___/ /_/ / /_/ / __/', + \ ' /_/ |_/ |___/\____/\____/\__,_/\___/ ', + \] + +let g:startify_session_dir = '~/.config/nvim/session' + + +let g:startify_lists = [ + \ { 'type': 'files', 'header': [' Files'] }, + \ { 'type': 'dir', 'header': [' Current Directory '. getcwd()] }, + \ { 'type': 'sessions', 'header': [' Sessions'] }, + \ { 'type': 'bookmarks', 'header': [' Bookmarks'] }, + \ ] + + +let g:startify_session_autoload = 1 +let g:startify_session_delete_buffers = 1 +let g:startify_change_to_vcs_root = 1 +let g:startify_fortune_use_unicode = 1 +let g:startify_session_persistence = 1 + +let g:webdevicons_enable_startify = 1 + +"function! StartifyEntryFormat() +" return 'WebDevIconsGetFileTypeSymbol(absolute_path) ." ". entry_path' +" endfunction + +let g:startify_bookmarks = [ + \ { 'c': '~/.config/i3/config' }, + \ { 'i': '~/.config/nvim/init.vim' }, + \ ] + +let g:startify_enable_special = 0 + -- cgit v1.2.3-70-g09d2