summaryrefslogtreecommitdiff
path: root/.config/nvim/plug-config
diff options
context:
space:
mode:
authoraktersnurra <gustaf.rydholm@gmail.com>2021-02-07 20:35:46 +0100
committeraktersnurra <gustaf.rydholm@gmail.com>2021-02-07 20:35:46 +0100
commita29fa44b3a0bd6f726ab2e8169dec35b697b04a0 (patch)
tree49e40e6e6b5b0378ea47638f77039bb4ae4c42b5 /.config/nvim/plug-config
parent251cde74e3bdfe70776aac644ee8858515fbc55c (diff)
neovim config added
Diffstat (limited to '.config/nvim/plug-config')
-rw-r--r--.config/nvim/plug-config/coc.vim200
-rw-r--r--.config/nvim/plug-config/polyglot.vim7
-rw-r--r--.config/nvim/plug-config/rnvimr.vim4
-rw-r--r--.config/nvim/plug-config/signify.vim16
-rw-r--r--.config/nvim/plug-config/sneak.vim25
-rw-r--r--.config/nvim/plug-config/start-screen.vim39
6 files changed, 291 insertions, 0 deletions
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 <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.
+if has('nvim')
+ inoremap <silent><expr> <c-space> coc#refresh()
+else
+ inoremap <silent><expr> <c-@> coc#refresh()
+endif
+
+" Make <CR> auto-select the first completion item and notify coc.nvim to
+" format on enter, <cr> could be remapped by other vim plugin
+inoremap <silent><expr> <cr> pumvisible() ? coc#_select_confirm()
+ \: "\<C-g>u\<CR>\<c-r>=coc#on_enter()\<CR>"
+
+" Use `[g` and `]g` to navigate diagnostics
+" Use `:CocDiagnostics` to get all diagnostics of current buffer in location list.
+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>')
+ elseif (coc#rpc#ready())
+ call CocActionAsync('doHover')
+ else
+ execute '!' . &keywordprg . " " . expand('<cword>')
+ 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 buffer.
+nmap <leader>ac <Plug>(coc-codeaction)
+" Apply AutoFix to problem on the current line.
+nmap <leader>qf <Plug>(coc-fix-current)
+
+" Map function and class text objects
+" NOTE: Requires 'textDocument.documentSymbol' support from the language server.
+xmap if <Plug>(coc-funcobj-i)
+omap if <Plug>(coc-funcobj-i)
+xmap af <Plug>(coc-funcobj-a)
+omap af <Plug>(coc-funcobj-a)
+xmap ic <Plug>(coc-classobj-i)
+omap ic <Plug>(coc-classobj-i)
+xmap ac <Plug>(coc-classobj-a)
+omap ac <Plug>(coc-classobj-a)
+
+" Remap <C-f> and <C-b> for scroll float windows/popups.
+if has('nvim-0.4.0') || has('patch-8.2.0750')
+ nnoremap <silent><nowait><expr> <C-f> coc#float#has_scroll() ? coc#float#scroll(1) : "\<C-f>"
+ nnoremap <silent><nowait><expr> <C-b> coc#float#has_scroll() ? coc#float#scroll(0) : "\<C-b>"
+ inoremap <silent><nowait><expr> <C-f> coc#float#has_scroll() ? "\<c-r>=coc#foat#scroll(1)\<cr>" : "\<Right>"
+ inoremap <silent><nowait><expr> <C-b> coc#float#has_scroll() ? "\<c-r>=coc#float#scroll(0)\<cr>" : "\<Left>"
+ vnoremap <silent><nowait><expr> <C-f> coc#float#has_scroll() ? coc#float#scroll(1) : "\<C-f>"
+ vnoremap <silent><nowait><expr> <C-b> coc#float#has_scroll() ? coc#float#scroll(0) : "\<C-b>"
+endif
+
+" Use CTRL-S for selections ranges.
+" Requires 'textDocument/selectionRange' support of language server.
+nmap <silent> <C-s> <Plug>(coc-range-select)
+xmap <silent> <C-s> <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 for CoCList
+" Show all diagnostics.
+nnoremap <silent><nowait> <space>a :<C-u>CocList diagnostics<cr>
+" Manage extensions.
+nnoremap <silent><nowait> <space>e :<C-u>CocList extensions<cr>
+" Show commands.
+nnoremap <silent><nowait> <space>c :<C-u>CocList commands<cr>
+" Find symbol of current document.
+nnoremap <silent><nowait> <space>o :<C-u>CocList outline<cr>
+" Search workspace symbols.
+nnoremap <silent><nowait> <space>s :<C-u>CocList -I symbols<cr>
+" Do default action for next item.
+nnoremap <silent><nowait> <space>j :<C-u>CocNext<CR>
+" Do default action for previous item.
+nnoremap <silent><nowait> <space>k :<C-u>CocPrev<CR>
+" Resume latest coc list.
+nnoremap <silent><nowait> <space>p :<C-u>CocListResume<CR>l
+
+" 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 <space>e :CocCommand explorer<CR>
+nmap <space>f :CocCommand explorer --preset floating<CR>
+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 <space>r :RnvimrToggle<CR>
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 <leader>gj <plug>(signify-next-hunk)
+nmap <leader>gk <plug>(signify-prev-hunk)
+nmap <leader>gJ 9999<leader>gJ
+nmap <leader>gK 9999<leader>gk
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 <Plug>Sneak_,
+map gs <Plug>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 <Plug>Sneak_f
+" map F <Plug>Sneak_F
+" map t <Plug>Sneak_t
+" map T <Plug>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
+