" #plugins {{{ if empty(glob('~/.vim/autoload/plug.vim'))"{{{ silent !curl -fLo ~/.vim/autoload/plug.vim --create-dirs \ https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim autocmd VimEnter * PlugInstall --sync | source $MYVIMRC endif "}}} call plug#begin('~/.vim/bundle') " #css3-syntax{{{ Plug 'hail2u/vim-css3-syntax' "}}} " #scss-syntax{{{ Plug 'cakebaker/scss-syntax.vim' "}}} " #vim-vue {{{ " https://github.com/posva/vim-vue Plug 'posva/vim-vue' " disable preprocessor checking for vue files - increases speed let g:vue_disable_pre_processors=0 " set custom syntax highlighting augroup fixhighlighting autocmd! autocmd BufNewFile,BufRead *.vue syntax sync fromstart augroup END " #vim-yaml " https://github.com/stephpy/vim-yaml Plug 'stephpy/vim-yaml' " #python-syntax " https://github.com/vim-python/python-syntax Plug 'vim-python/python-syntax' let g:python_highlight_all = 1 "}}} "#html5{{{ " https://github.com/othree/html5.vim Plug 'othree/html5.vim' "}}} " #php.vim{{{ " https://github.com/StanAngeloff/php.vim Plug 'StanAngeloff/php.vim' "}}} "#vim-json{{{ " https://github.com/elzr/vim-json Plug 'elzr/vim-json' "}}} "#i3config.vim{{{ " https://github.com/mboughaba/i3config.vim Plug 'mboughaba/i3config.vim' "}}} " #tagbar {{{ Plug 'majutsushi/tagbar' nnoremap <space>tb :TagbarOpen fj<CR> nnoremap <space>] :tag /[.#@]<c-r>=expand('<cword>')<cr><cr> let g:tagbar_autoclose = 1 " let g:tagbar_autopreview = 1 " let g:tagbar_previewwin_pos = '' let g:tagbar_type_css = { \ 'ctagstype' : 'css', \ 'kinds' : [ \ 'c:classes', \ 'i:ids', \ 't:tags', \ 'm:medias' \ ] \} let g:tagbar_type_scss = { \ 'ctagstype' : 'scss', \ 'kinds' : [ \ 'v:variables', \ 'c:classes', \ 'i:ids', \ 't:tags', \ 'd:medias', \ 'm:mixins', \ 'f:functions' \ ] \} let g:tagbar_type_vue = { \ 'ctagstype' : 'vue', \ 'kinds' : [ \ 'o:objects', \ 'f:functions', \ 'a:array', \ 's:string', \ 'b:boolean', \ 'n:number', \ 'v:variable' \ ] \ } "}}} " #vim-surround{{{ Plug 'tpope/vim-surround' "}}} " #undotree {{{ Plug 'mbbill/undotree' "}}} " #Ctrlp {{{ Plug 'ctrlpvim/ctrlp.vim' " :h ctrlp-commands " :h ctrlp-extensions let g:ctrlp_extensions = ['tag', 'buffertag', 'quickfix', 'undo'] if executable('ag') " Use ag in CtrlP for listing files. Lightning fast and respects .gitignore let g:ctrlp_user_command = 'ag %s -l --nocolor -g ""' " ag is fast enough that CtrlP doesn't need to cache let g:ctrlp_use_caching = 0 endif " Use ag over grep if executable('ag') set grepprg=ag\ --nogroup\ --nocolor\ --ignore\ node_modules endif "}}} " #Obsession{{{ Plug 'tpope/vim-obsession' "}}} " #vim-javascript{{{ Plug 'pangloss/vim-javascript' "}}} " #ultisnips {{{ " https://github.com/sirver/UltiSnips Plug 'SirVer/ultisnips' " and some snippets " https://github.com/honza/vim-snippets " Plug 'honza/vim-snippets' nnoremap <space>ul :call ListUltisnips()<cr> inoremap jkul <c-o>:call ListUltisnips()<cr> let g:UltiSnipsSnippetsDir='~/.vim/UltiSnips' " Trigger configuration. Do not use <tab> if you use https://github.com/Valloric/YouCompleteMe. let g:UltiSnipsExpandTrigger='<c-j>' let g:UltiSnipsJumpForwardTrigger='<tab>' let g:UltiSnipsJumpBackwardTrigger='<s-tab>' let g:UltiSnipsEditSplit='horizontal' function! ListUltisnips() abort"{{{ let l:snips = UltiSnips#SnippetsInCurrentScope(1) let l:keylist = sort(keys(l:snips)) echo ' --------------------------------------------------' for l:key in l:keylist echo printf(" %-10s\t%s", l:key, l:snips[l:key]) endfor echo '---------------------------------------------------' endfunction "}}} function! CompleteSnippets(findstart, base)"{{{ if a:findstart let l:line = getline('.') let l:start = col('.') - 1 while l:start > 0 && l:line[l:start - 1] =~ '\a' let l:start -= 1 endwhile return l:start else let l:res = [] let l:snips = UltiSnips#SnippetsInCurrentScope(1) let l:keylist = sort(keys(l:snips)) for l:key in l:keylist if l:key =~ '^' . a:base let l:item = {'word': l:key, 'menu': l:snips[l:key]} call add(l:res, l:item) endif endfor return l:res endif endfunction "}}} set completefunc=CompleteSnippets "}}} " #ALE {{{ " https://github.com/w0rp/ale Plug 'w0rp/ale' nnoremap <space>ne :lnext<cr> nnoremap <space>pe :lprev<cr> let g:ale_sign_error = '>>' let g:ale_sign_warning = '>' let g:ale_sign_column_always = 1 let g:ale_open_list = 0 " let g:ale_linters = {'scss': ['stylelint'], 'javascript': ['eslint'], 'php':['php'], 'html':['htmlhint'], 'python': [], 'vue': []} let g:ale_linters = {'scss': ['stylelint'], 'javascript': [], 'php':['php'], 'html':['htmlhint'], 'python': [], 'vue': []} " let g:ale_linters_explicit = 1 let g:ale_html_htmlhint_options = '-c ~/.htmlhintrc --format=unix' let g:ale_fixers = {'javascript': ['eslint']} "}}} " #MatchTagAlways{{{ " https://github.com/Valloric/MatchTagAlways Plug 'Valloric/MatchTagAlways' "}}} " #phpcomplete.vim{{{ " https://github.com/shawncplus/phpcomplete.vim Plug 'shawncplus/phpcomplete.vim' " https://github.com/dsawardekar/wordpress.vim " For up to date Wordpress Files see: " https://github.com/joseluis/wordpress.vim-generator "}}} " #wordpress.vim{{{ " doesn't support universal ctags " #Plug 'dsawardekar/wordpress.vim' " This fork does: " https://github.com/DArcMattr/wordpress.vim/tree/universal-ctags " Using studio-vx fork Plug 'studio-vx/wordpress.vim', { 'branch': 'universal-ctags' } "}}} " #vim-commentary{{{ " https://github.com/tpope/vim-commentary Plug 'tpope/vim-commentary' "}}} " #vim-repeat{{{ " https://github.com/tpope/vim-repeat Plug 'tpope/vim-repeat' "}}} " #emmet-vim {{{ " https://github.com/mattn/emmet-vim Plug 'mattn/emmet-vim' let g:user_emmet_leader_key=',,' let g:user_emmet_settings = { \ 'indentation': ' ', \} "}}} " #vimwiki {{{ " https://github.com/vimwiki/vimwiki Plug 'vimwiki/vimwiki' let g:vimwiki_list = [{'path': '~/vimwiki/', 'path_html': '~/vimwiki_html/'}] "}}} " #vim-gutentags {{{ " https://github.com/ludovicchabant/vim-gutentags Plug 'ludovicchabant/vim-gutentags' let g:gutentags_ctags_tagfile = '.tags' let g:gutentags_ctags_exclude = ['package.json', 'Session.vim', 'package-lock.json', 'TODO.txt'] "}}} " #vim-dispatch{{{ " https://github.com/tpope/vim-dispatch Plug 'tpope/vim-dispatch' "}}} " #colorV {{{ " original: " https://github.com/gu-fan/colorv.vim " Plug 'gu-fan/colorv.vim' " custom fork: " https://github.com/studio-vx/colorv.vim Plug 'studio-vx/colorv.vim' let g:ColorVForceGuiColors = 1 let g:colorv_no_global_map = 1 let g:colorv_win_pos = 'top' let g:colorv_preview_area = 0 nnoremap <space>cv :ColorV<CR> nnoremap <space>ce :ColorVEdit<CR> nnoremap <space>cc :call ToggleColorPreview()<CR> nnoremap <space>ci :ColorVInsert<CR> nnoremap <space>cp :ColorVPicker<CR> let w:colorv_is_previewing = 0 function! ToggleColorPreview() abort "{{{ if !exists('w:colorv_is_previewing') let w:colorv_is_previewing = 0 endif if w:colorv_is_previewing == 0 execute 'ColorVPreview' let w:colorv_is_previewing = 1 else execute 'ColorVClear' let w:colorv_is_previewing = 0 endif endfunction "}}} "}}} " #switch {{{ "https://github.com/AndrewRadev/switch.vim Plug 'AndrewRadev/switch.vim' let g:switch_mapping = '<space>-' let g:switch_custom_definitions = [ \ ['0', '1'], \ ['ease-in', 'ease-out', 'ease-in-out', 'linear'], \ ['auto', 'none'], \ ['left', 'right'], \ ['top', 'bottom'], \ ['row', 'column'], \ ['relative', 'absolute', 'fixed'] \ ] "}}} " #gitgutter {{{ " https://github.com/airblade/vim-gitgutter/blob/master/README.mkd Plug 'airblade/vim-gitgutter' nmap ]h <Plug>GitGutterNextHunk nmap [h <Plug>GitGutterPrevHunk omap ih <Plug>GitGutterTextObjectInnerPending omap ah <Plug>GitGutterTextObjectOuterPending xmap ih <Plug>GitGutterTextObjectInnerVisual xmap ah <Plug>GitGutterTextObjectOuterVisual "}}} " #fugitive-vim{{{ " https://github.com/tpope/vim-fugitive/blob/master/README.markdown Plug 'tpope/vim-fugitive' "}}} " #vim-git{{{ " https://github.com/tpope/vim-git Plug 'tpope/vim-git' "}}} " #gitv{{{ " https://github.com/gregsexton/gitv Plug 'gregsexton/gitv' "}}} " #wakatime{{{ " https://wakatime.com/vim Plug 'wakatime/vim-wakatime' "}}} " #vim-easy-align {{{ " https://github.com/junegunn/vim-easy-align Plug 'junegunn/vim-easy-align' xmap ga <Plug>(EasyAlign) nmap ga <Plug>(EasyAlign) "}}} " #vim-lsp {{{ " https://github.com/prabirshrestha/vim-lsp Plug 'prabirshrestha/async.vim' Plug 'prabirshrestha/vim-lsp' let g:lsp_signs_enabled = 1 let g:lsp_signs_error = {'text': '>>'} let g:lsp_signs_warning = {'text': '>'} let g:lsp_signs_information = {'text': '--'} let g:lsp_signs_hint = {'text': '--'} let g:lsp_diagnostics_echo_cursor = 1 let g:lsp_diagnostics_echo_delay = 0 nnoremap \l :cclose<CR>:LspDocumentDiagnostics<cr> nnoremap \h :LspHover<cr> nnoremap \d :LspDefinition<cr> nnoremap \r :LspReferences<cr> nnoremap \n :LspRename<cr> nnoremap \s :LspDocumentSymbol<cr> nnoremap \w :LspWorkspaceSymbol<cr> nnoremap \ff :LspDocumentFormat<cr> nnoremap \fr :LspDocumentRangeFormat<cr> augroup User lsp_setup autocmd! if executable('vls') autocmd User lsp_setup call lsp#register_server({ \ 'name': 'vue', \ 'cmd': {server_info->['vls']}, \ 'whitelist': ['vue'], \ }) endif if executable('pyls') autocmd User lsp_setup call lsp#register_server({ \ 'name': 'pyls', \ 'cmd': {server_info->['pyls']}, \ 'whitelist': ['python'], \ }) endif if executable('typescript-language-server') au User lsp_setup call lsp#register_server({ \ 'name': 'typescript-language-server', \ 'cmd': { server_info->[&shell, &shellcmdflag, 'typescript-language-server --stdio']}, \ 'root_uri': { server_info->lsp#utils#path_to_uri(lsp#utils#find_nearest_parent_directory(lsp#utils#get_buffer_path(), '.git/..'))}, \ 'whitelist': ['typescript', 'javascript', 'javascript.jsx'] \ }) endif augroup END "}}} " #inline_edit.vim {{{ " https://github.com/AndrewRadev/inline_edit.vim Plug 'AndrewRadev/inline_edit.vim' let g:inline_edit_patterns = [{ \ 'main_filetype': '*html', \ 'sub_filetype': 'scss', \ 'indent_adjustment': 1, \ 'start': '<style\>[^>]*lang=.scss[^>]*>', \ 'end': '</style>' \ }] let g:inline_edit_autowrite = 1 let g:inline_edit_proxy_type = 'tempfile' let g:inline_edit_new_buffer_command ='tabedit' let g:inline_edit_modify_statusline = 0 nnoremap <space>ie :InlineEdit<cr> "}}} " #Netrw {{{ let g:netrw_liststyle=3 let g:netrw_list_hide='^\..*' let g:netrw_preview = 0 "}}} " #Activity Watch #aw-watcher-vim{{{ " https://github.com/ActivityWatch/aw-watcher-vim Plug 'ActivityWatch/aw-watcher-vim' "}}} call plug#end() runtime macros/matchit.vim "----------------------------------------------------------------------------}}} " #functions {{{ function! DoInsertEnter() "{{{ " call SetColor('LineNr', '#262626', '', '#cccccc', '', '') " call SetColor('CursorLineNr', '#bcbcbc', '', '#999999', '', 'bold') endfunction "}}} function! DoInsertLeave() "{{{ " call SetColor('LineNr', '#3a3a3a', '', '#999999', '', '') " call SetColor('CursorLineNr', '#767676', '', '#777777', '', 'bold') endfunction "}}} function! SetColor(name, fg, bg, fg_l, bg_l, style) abort"{{{ if &background ==? 'dark' if a:fg ==? 'normal' let l:guifg = ' guifg=' . g:d_normal_fg let l:ctermfg = 'ctermfg=black' " let l:termfg = 'termfg=black' elseif a:fg ==? 'none' let l:guifg = ' guifg=' . g:d_normal_bg let l:ctermfg = ' ctermfg=white' " let l:termfg = ' termfg=white' elseif a:fg ==? '' let l:guifg = '' let l:ctermfg = '' " let l:termfg = '' else let l:guifg = ' guifg=' . a:fg let l:ctermfg = ' ctermfg=black' " let l:termfg = ' termfg=black' endif if a:bg ==? 'none' let l:guibg = ' guibg=NONE' let l:ctermbg = ' ctermbg=none' " let l:termbg = ' termbg=none' elseif a:bg ==? '' let l:guibg = '' let l:ctermbg = '' " let l:termbg = '' else let l:guibg = ' guibg=' . a:bg let l:ctermbg = ' ctermbg=black' endif else " light background if a:fg_l ==? 'normal' let l:guifg = ' guifg=' . g:l_normal_fg let l:ctermfg = ' ctermfg=black' " let l:termfg = ' termfg=black' elseif a:fg_l ==? 'none' let l:guifg = ' guifg=' . g:l_normal_bg let l:ctermfg = ' ctermfg=white' " let l:termfg = ' termfg=white' elseif a:fg_l ==? '' let l:guifg = '' let l:ctermfg = '' let l:termfg = '' else let l:guifg = ' guifg=' . a:fg_l let l:ctermfg = ' ctermfg=black' " let l:termfg = ' termfg=black' endif if a:bg_l ==? 'none' let l:guibg = ' guibg=NONE' let l:ctermbg = ' ctermbg=none' " let l:termbg = ' termbg=none' elseif a:bg_l ==? '' let l:guibg = '' let l:ctermbg = '' " let l:termbg = '' else let l:guibg = ' guibg=' . a:bg_l let l:ctermbg = ' ctermbg=white' " let l:termbg = ' termbg=white' endif endif if a:style ==? '' let l:style = ' term=none cterm=none gui=NONE' else let l:style = ' term=' . a:style . ' cterm=' . a:style . ' gui=' . a:style endif let l:histring = 'hi! ' . a:name . l:guifg . l:guibg . l:style let l:histring .= l:ctermfg . l:ctermbg " let l:histring .= l:termfg . l:termbg execute 'hi clear ' . a:name execute l:histring endfunction "}}} function! GetStatusFrag(condition, colorname, conditionprefix, text) abort "{{{ " TODO better name let l:frag='%#' . a:colorname . '#' let l:frag.=a:conditionprefix let l:frag.='%{(' . a:condition . ")?'" . a:text . "':''}" return l:frag endfunction "}}} function! MyFoldText() "{{{ if !exists('g:foldtext_column') let g:foldtext_column = 80 " column to right align foldtext with endif if !exists('b:foldtext_column') let b:foldtext_column = g:foldtext_column " column to right align foldtext with endif if !exists('g:foldtext_maxcolumn') let g:foldtext_maxcolumn = 120 endif let l:linecount = v:foldend - v:foldstart " don't display foldmarker braces " put one of the braces in brackets so vim doesn't treat " it as an actual fold marker let l:line = substitute(getline(v:foldstart), '"\?{\({\){', '', '') " don't display vim comment quotation marks let l:line = substitute(l:line, "\^\"\\s\\?", '', '') let l:postfix = l:linecount . ' ' . substitute(v:folddashes, '-', '•', 'g') while strchars(l:postfix) < 7 let l:postfix = ' ' . l:postfix endwhile let l:postfix = ' ↓ ' . l:postfix let l:len_line = len(l:line) let l:len_postfix = strchars(l:postfix) if l:len_line + l:len_postfix <= b:foldtext_column let l:padding = ' '[l:len_line + l:len_postfix + 0:b:foldtext_column - 1] let l:foldtext = l:line . l:padding . l:postfix else let l:sniptext = ' ⋯' let l:foldtext = l:line[:b:foldtext_column - 1 - strchars(l:sniptext) - l:len_postfix] . l:sniptext . l:postfix endif return l:foldtext endfunction "}}} function! IndentFoldTextColumn(amount) abort "{{{ if !exists('g:foldtext_column') " column to right align foldtext with let g:foldtext_column = 80 endif if !exists('b:foldtext_column') " column to right align foldtext with let b:foldtext_column = g:foldtext_column endif if a:amount == 0 let b:foldtext_column = g:foldtext_column return endif let l:newcolumn = b:foldtext_column + a:amount if l:newcolumn < 20 let l:newcolumn = 20 elseif l:newcolumn > g:foldtext_maxcolumn let l:newcolumn = g:foldtext_maxcolumn endif let b:foldtext_column = l:newcolumn endfunction nnoremap <space>z, :<C-U>call IndentFoldTextColumn(-5 * (v:count == 0 ? 1 : v:count))<CR> nnoremap <space>z. :<C-U>call IndentFoldTextColumn(5 * (v:count == 0 ? 1 : v:count))<CR> nnoremap <space>z= :call IndentFoldTextColumn(0)<CR> "}}} function! SyntaxItem() abort "{{{ " get name of syntax item return synIDattr(synID(line('.'),col('.'),1),'name') . ' -> ' . synIDattr(synIDtrans(synID(line('.'),col('.'),1)), 'name' ) endfunction nnoremap <space>pp :echom SyntaxItem()<CR> "}}} function! s:Get_env() abort "{{{ " devdocs DD " https://gist.github.com/romainl/8d3b73428b4366f75a19be2dad2f0987#file-devdocs-vim if has('win64') || has('win32') || has('win16') return 'WINDOWS' else return toupper(substitute(system('uname'), '\n', '', '')) endif endfunction " What command to use on what system let s:cmds = {'DARWIN': 'open', 'LINUX': 'qutebrowser', 'WINDOWS': 'start'} " Build the URL stub let s:stub = s:cmds[<SID>Get_env()] . " 'http://devdocs.io/?q=" command! -nargs=* DD silent! call system(len(split(<q-args>, ' ')) == 0 ? \ s:stub . &ft . ' ' . expand('<cword>') . "'" : len(split(<q-args>, ' ')) == 1 ? \ s:stub . &ft . ' ' . <q-args> . "'" : s:stub . <q-args> . "'") "}}} if !exists('*RangerExplorer') "{{{ " use ranger as file manager function RangerExplorer() abort exec 'silent !ranger --choosefile=/tmp/vim_ranger_current_file ' . expand('%:p:h') if filereadable('/tmp/vim_ranger_current_file') exec 'edit ' . system('cat /tmp/vim_ranger_current_file') call system('rm /tmp/vim_ranger_current_file') endif redraw! endfun map <space>ra :call RangerExplorer()<CR> endif "}}} function! SetColorColumn() abort"{{{ if &buftype == '' setlocal colorcolumn=80,120 endif endfunction "}}} function! GetLinterStatus(key) abort "{{{ let l:statuscount = 0 if exists('b:ale_linted') let l:linter = ale#statusline#Count(bufnr('')) else let l:linter = GetDiagnosticCountsFromSigns(bufnr('')) endif if has_key(l:linter, a:key) let l:statuscount = l:linter[a:key] endif return l:statuscount endfunction "}}} function! s:RunShellCommand(cmdline) abort"{{{ " Shell command " http://vim.wikia.com/wiki/VimTip1599 let l:expanded_cmdline = a:cmdline for l:part in split(a:cmdline, ' ') if l:part[0] =~ '\v[%#<]' let l:expanded_part = fnameescape(expand(l:part)) let l:expanded_cmdline = substitute(l:expanded_cmdline, l:part, l:expanded_part, '') endif endfor if g:shell_scratch_buffer_nr > -1 let l:win_nr = bufwinnr(g:shell_scratch_buffer_nr) if l:win_nr < 0 execute 'bdelete' g:shell_scratch_buffer_nr top new let g:shell_scratch_buffer_nr = bufnr('%') else execute l:win_nr. ' wincmd w' setlocal modifiable %delete _ endif else top new let g:shell_scratch_buffer_nr = bufnr('%') endif setlocal buftype=nofile bufhidden=wipe nobuflisted noswapfile nowrap nnoremap <buffer> q :bdelete<CR> augroup ResetShellBufferNr autocmd! * <buffer> autocmd BufUnload <buffer> let g:shell_scratch_buffer_nr = -1 augroup END " call setline(1, 'You entered: ' . a:cmdline) " call setline(2, 'Expanded Form: ' .l:expanded_cmdline) " call setline(3,substitute(getline(2),'.','=','g')) execute '$read !'. l:expanded_cmdline 1 setlocal nomodifiable if !exists('b:shell_line_count') let b:shell_line_count = line('$') if b:shell_line_count > 25 let b:shell_line_count = 20 endif execute 'resize' b:shell_line_count + 1 endif wincmd p endfunction command! -complete=shellcmd -nargs=+ Shell call s:RunShellCommand(<q-args>) let g:shell_scratch_buffer_nr = -1 "}}} function! GetDiagnosticCountsFromSigns(buffer) abort "{{{ let l:error = 0 let l:warn = 0 let l:info = 0 let l:hint = 0 redir => l:result silent exec 'sign place buffer=' . a:buffer redir end let l:lines = split(l:result, '\n') for l:line in l:lines if l:line =~? 'Error' let l:error += 1 endif if l:line =~? 'Warning' let l:warn += 1 endif if l:line =~? 'Info' let l:info += 1 endif if l:line =~? 'Hint' let l:hint += 1 endif endfor return {'error': l:error, 'warning': l:warn, 'info': l:info, 'hint': l:hint} endfunction "}}} function! SaveAndExecute(ex_command) abort "{{{ " https://stackoverflow.com/a/40195855 " ex_command: command to run to execute file " SOURCE [reusable window]: https://github.com/fatih/vim-go/blob/master/autoload/go/ui.vim " save and reload current file silent execute 'update | edit' " get file path of current file let s:current_buffer_file_path = expand('%') let s:output_buffer_name = 'Output' let s:output_buffer_filetype = 'output' " reuse existing buffer window if it exists otherwise create a new one if !exists('c:buf_nr') || !bufexists(s:buf_nr) || bufwinnr(s:buf_nr) == -1 silent execute 'top new ' . s:output_buffer_name let s:buf_nr = bufnr('%') elseif bufwinnr(s:buf_nr) != bufwinnr('%') silent execute bufwinnr(s:buf_nr) . 'wincmd w' endif silent execute 'setlocal filetype=' . s:output_buffer_filetype setlocal bufhidden=delete setlocal buftype=nofile setlocal noswapfile setlocal nobuflisted setlocal winfixheight setlocal cursorline " make it easy to distinguish setlocal nonumber setlocal norelativenumber setlocal showbreak="" nnoremap <silent> <buffer> q :bdelete!<CR>'.zz " clear the buffer setlocal noreadonly " setlocal modifiable %delete _ " add the console output silent execute '.!'. a:ex_command . ' ' . shellescape(s:current_buffer_file_path, 1) " resize window to content length " Note: This is annoying because if you print a lot of lines then your code buffer is forced to a height of one line every time you run this function. " However without this line the buffer starts off as a default size and if you resize the buffer then it keeps that custom size after repeated runs of this function. " But if you close the output buffer then it returns to using the default size when its recreated "execute 'resize' . line('$') " make the buffer non modifiable setlocal readonly " setlocal nomodifiable endfunction "}}} function! JsIncludeExpr(file)"{{{ " substitute(substitute(v:fname,'^[\\~@]\/','./',''),'^[\\~@]','./node_modules/','') echom v:fname return substitute(substitute(a:file,'^[\\~@]\/','./',''),'^[\\~@]','./node_modules/','') endfunction "}}} "----------------------------------------------------------------------------}}} " #settings {{{ scriptencoding utf-8 set ttyfast if &term ==? 'xterm-256color' set termguicolors endif syntax on set background=light " set fillchars=stl:\ ,stlnc:\ ,vert:│ set fillchars=stl:\ ,stlnc:\ ,vert:┃ colorscheme monotonous-dark set guioptions-=mTrLb set guioptions+=c set updatetime=100 set timeoutlen=500 set lazyredraw set backupdir=~/.vimtmp set directory=~/.vimtmp set tags+=./.tags,.tags;/home/ray/ " persisitent undo file set undodir=/home/ray/.vim/undodir set undofile set viewoptions-=options set ignorecase set smartcase set wildmenu set wildmode=longest:full,full set wildignore+=/node_modules/,dist/ " Use ag over grep if executable('ag') set grepprg=ag\ --nogroup\ --nocolor\ --ignore\ node_modules endif set hidden set number relativenumber set hlsearch " set previewheight=24 " set splitbelow set completeopt=longest,menuone set completeopt-=preview set nospell set spelllang=en_gb set dictionary+=/usr/share/dict/brit-a-z.txt,/usr/share/dict/britcaps.txt set thesaurus+=/usr/share/dict/mthesaur.txt set tabstop=8 set softtabstop=2 set shiftwidth=2 set shiftround set expandtab set autoindent set textwidth=180 set formatoptions=cq set wrapmargin=0 set cursorline set foldcolumn=2 set signcolumn=yes set colorcolumn=80,120 set iskeyword+=- set scrolloff=10 set showcmd set incsearch set laststatus=2 set shortmess=aoOT set cmdheight=3 if &filetype ==? 'vim' set foldmethod=marker else set foldmethod=manual endif set showmode set autoindent set breakindent set showbreak=\ \ ↳\ set mouse=a set listchars=eol:¬,tab:>-,trail:~,extends:>,precedes:<,space:· set foldtext=MyFoldText() "----------------------------------------------------------------------------}}} " #mappings {{{ let g:mapleader = ' ' nnoremap <space>ut :UndotreeToggle<cr> " miscallaneous {{{ nnoremap : :setlocal norelativenumber<CR>: nnoremap <silent> <space>rc :so $MYVIMRC<CR> nnoremap <silent> <space>nn :set invrelativenumber<CR> nnoremap <silent><expr> <space>nh (&hls && v:hlsearch ? ':nohls' : ':set hls')."\n" nnoremap <silent> <space>sl :set invlist<CR> nnoremap <space>aa A<left> nnoremap <space>a2 A<left><left> nnoremap <space>ab A<C-o>B nnoremap <space>co :!clear; " Focus on current fold, close the rest nnoremap <silent> <space>zz zMzvzt " replace current word with last yanked/deleted text nnoremap <silent> <space>rr "_diwP " replace current word with last yanked text nnoremap <silent> <space>ry diw"0P " quick grep of visual selection vnoremap <space>gr y:grep! -R <C-r>" . " open quickfix window of TODOs nnoremap <space>td :grep! -R '// *TODO' .<CR>:botright cwindow<CR>:echo len(getqflist()) 'TODOs'<CR> " devdocs mapping nnoremap <space>dd :DD<CR> " write and delete current buffer nnoremap <space>bx :w\|bd<cr> "}}} " terminal{{{ tnoremap <Esc> <C-\><C-n> "}}} " git mappings {{{ nnoremap <space>gs :Gstatus<CR> nnoremap <space>gd :Gdiff<CR> nnoremap <space>gD :!clear; echo 'git diff'; git diff<CR> nnoremap <space>ga :!clear; git add %; git status<CR> nnoremap <space>gA :!clear; git add .; git status<CR> nnoremap <space>gc :Gcommit<CR> nnoremap <space>gg :!clear; git add %; git commit -m ''<Left> nnoremap <space>gp :!clear; echo 'git push'; git push<CR> " nnoremap <space>gp :terminal echo ':git push' & git push<CR> " nnoremap <space>gp :Gpush<CR> " nnoremap <space>gp :pedit | read ! echo 'git push'; git push<CR> nnoremap <space>gl :Glog<CR> "}}} " netrw {{{ nnoremap <space>ex :Ex<CR> nnoremap <space>ee :e .<CR> nnoremap <space>eq :Rex<CR> "}}} " better window/tab/buffer navigation/management {{{ nnoremap <Esc>j :resize -5<CR> nnoremap <Esc>k :resize +5<CR> nnoremap <Esc>l :vertical resize +5<CR> nnoremap <Esc>h :vertical resize -5<CR> "}}} "location list and quickfix mappings {{{ nnoremap <space>lo :botright lwindow<CR> nnoremap <up> :lprev<CR>zv nnoremap <down> :lnext<CR>zv nnoremap <space>lc :lclose<CR> nnoremap <space>lh :lhistory<CR> nnoremap <space>lp :lolder<CR> nnoremap <space>ln :lnewer<CR> nnoremap <space>qo :botright cwindow<CR> nnoremap <left> :cprev<CR>zv nnoremap <right> :cnext<CR>zv nnoremap <space>qc :cclose<CR> nnoremap <space>qh :chistory<CR> nnoremap <space>qp :colder<CR> nnoremap <space>qn :cnewer<CR> "}}} " insert mode mappings {{{ inoremap jkrg <c-o>:reg<cr> inoremap :w<cr> :w<cr> inoremap [:w<cr> :w<cr> inoremap {:w<cr> :w<cr> "}}} " brace/quotes completion {{{ inoremap {{ {}<left> inoremap {<CR> {<CR>}<C-o>O inoremap {; {<CR>};<C-o>O inoremap {, {<CR>},<C-o>O inoremap {{{ {{}}<Left><Left> inoremap (( ()<Left> inoremap (<CR> (<CR>)<C-o>O inoremap (; ();<Left><Left> inoremap (, (),<Left><Left> inoremap [[ []<Left> inoremap [<CR> [<CR>]<C-o>O inoremap "" ""<Left> inoremap """ "" inoremap "; "";<Left><Left> inoremap '' ''<Left> inoremap ''' '' inoremap '; '';<Left><Left> "}}} "}}} "----------------------------------------------------------------------------}}} " #abbreviations {{{ " spelling"{{{ iabbrev adn and iabbrev waht what iabbrev tehn then iabbrev functin function iabbrev positin position "}}} " css{{{ iabbrev pabs; position: absolute; iabbrev pfix; position: fixed; iabbrev prel; position: relative; iabbrev fdr; flex-direction: row; iabbrev fdc; flex-direction: column; iabbrev jcc; justify-content: center; iabbrev aic; align-items: center; iabbrev t0; top: 0; iabbrev b0; bottom: 0; iabbrev l0; left: 0; iabbrev r0; right: 0; iabbrev ct'' content-type: ''; "}}} "----------------------------------------------------------------------------}}} " #autocommands {{{ " persistent folds {{{ augroup AutoSaveFolds autocmd! " autocmd BufWinLeave ?* mkview autocmd BufWrite ?* mkview " autocmd BufWinEnter ?* silent loadview autocmd BufRead ?* silent loadview augroup END "}}} " Show trailing whitepace and spaces before a tab: {{{ augroup whitespaceerrors autocmd! autocmd Syntax * syn match ExtraWhitespace /\s\+$\| \+\ze\t/ containedin=ALL augroup END "}}} " automatically reload if color scheme file written {{{ " augroup coloreload " autocmd! " autocmd BufWritePost customred256.vim so $MYVIMRC " augroup end " "}}} " line numbering {{{ augroup linenumbering autocmd! autocmd InsertEnter * :set norelativenumber autocmd InsertLeave * :set number relativenumber autocmd WinEnter * :set number relativenumber autocmd WinLeave * set norelativenumber autocmd CmdlineEnter * :redraw | :set norelativenumber autocmd CmdlineLeave * :set number relativenumber " see 'mapping nnoremap :' for setting norelative number. augroup END "}}} " WinEnter, WinLeave {{{ augroup windowenteringleaving autocmd! autocmd WinEnter * call SetColorColumn() autocmd WinEnter * set cursorline | set cursorcolumn autocmd WinLeave * setlocal colorcolumn=0 autocmd WinLeave * set nocursorline | set nocursorcolumn augroup END "}}} " InsertEnter, InsertLeave {{{ augroup insertenterleave au! au InsertEnter * call DoInsertEnter() au InsertLeave * call DoInsertLeave() augroup END "}}} " Automatically reload .vimrc if chanaged {{{ augroup myvimrc autocmd! autocmd BufWritePost .vimrc,_vimrc,vimrc,.gvimrc,_gvimrc,gvimrc so $MYVIMRC | if has('gui_running') | so $MYGVIMRC | endif augroup END "}}} " Open qfix after grepping {{{ augroup qfixopen autocmd! autocmd QuickFixCmdPost *grep* botright cwindow augroup END "}}} "----------------------------------------------------------------------------}}} " #statusline {{{ set statusline=%!GetStatus(1) function! GetStatus(isactive) abort "{{{ " let l:linter = ale#statusline#Count(bufnr('')) let l:divider = '- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - >' let l:separator = '%#StatusLineSeparator# ' let l:normal = '%#StatusLineNormal#' let l:active = '%#StatusLineActive#' let l:linterdash = '%#LinterDash#·' let l:linterdashactive = '%#LinterDashActive#·' let l:statusline = l:separator "buffer number {{{ if a:isactive let l:statusline .= '%#StatusLineBufferNrActive#' else let l:statusline .= '%#StatusLineBufferNr#' endif let l:statusline .= ' %n ' . l:separator "}}} " file percentage {{{ if a:isactive let l:statusline .= '%#StatusLinePercentActive#' let l:statusline .= ' %P %#StatusLineNoiseActive#of %#StatusLineLinecountActive#%L ' else let l:statusline .= '%#StatusLinePercent#' let l:statusline .= ' %P %#StatusLineNoise#of %#StatusLineLinecount#%L ' endif"}}} " non-empty buftype (help, quickfix, etc) {{{ if a:isactive let l:statusline .= l:active . "%{&buftype == '' ? '' : ' '}%q%h%w%#StatusLineActiveNoText#" else let l:statusline .= l:normal . "%{&buftype == '' ? '' : ' '}%q%h%w%#StatusLineNormalNoText#" endif let l:statusline .= "%{&buftype == '' ? '' : ' '}%s" "}}} " right/left divider {{{ let l:statusline.=l:separator " modified version let l:color = 'StatusLineDivMod' . (a:isactive?'Active':'') let l:statusline .= GetStatusFrag("&modified && mode() != 'i'", l:color, '%<', l:divider) " unmodified version let l:color = 'StatusLineDiv' . (a:isactive?'Active':'') let l:statusline .= GetStatusFrag("!&modified && mode() != 'i'", l:color, '%<', l:divider) " input mode version if a:isactive let l:statusline .= GetStatusFrag("mode() == 'i'", 'StatusLineDivInput', '%<', l:divider) endif let l:statusline.= l:separator . '%*%=' "}}} " file info{{{ if a:isactive == 1 " let l:statusline.=l:active let l:statusline.='%#StatusLineFileInfo#' " let l:statusline.=" %{strlen(&ft)?&ft:'none'} " " let l:statusline.=l:separator . l:active let l:statusline.='%{strlen(&fenc)?&fenc:&enc}' " let l:statusline.=l:separator . l:active let l:statusline.=' %{&fileformat}' let l:statusline.="%{strlen(expand('%:e')) > 1?' ' . expand('%:e'):''}" " let l:statusline.=l:separator . l:active " let l:statusline.=' %{&spelllang} ' let l:statusline .= l:separator endif "}}} " path/filename.extension {{{ if a:isactive if &readonly let l:statusline .= '%#StatusLineWarningActive# %r ' let l:statusline .= '%#StatusLineFileReadOnlyActive#' " let l:statusline.='%#StatusLineDirActive# ' let l:statusline.="%{expand('%:p:h:t')}/" " let l:statusline.='%#StatusLineFileActive#' let l:statusline.="%{expand('%:t:r')}" " let l:statusline.='%#StatusLineDotActive#' let l:statusline.="%{strlen(expand('%:e'))?'.':''}" " let l:statusline.='%#StatusLineExtActive#' let l:statusline.="%{strlen(expand('%:e'))?expand('%:e'):expand('%:e')} " else let l:statusline.='%#StatusLineDirActive# ' let l:statusline.="%{expand('%:p:h:t')}/" let l:statusline.='%#StatusLineFileActive#' let l:statusline.="%{expand('%:t:r')}" let l:statusline.='%#StatusLineDotActive#' let l:statusline.="%{strlen(expand('%:e'))?'.':''}" let l:statusline.='%#StatusLineExtActive#' let l:statusline.="%{strlen(expand('%:e'))?expand('%:e'):expand('%:e')} " endif else let l:statusline .= ' %#StatusLineWarning#%r' let l:statusline.='%#StatusLineDir# ' let l:statusline.="%{fnamemodify(expand('%:p:h'),':~')}/" let l:statusline.='%#StatusLineFile#' let l:statusline.="%{expand('%:t:r')}" let l:statusline.='%#StatusLineDot#' let l:statusline.="%{strlen(expand('%:e'))?'.':''}" let l:statusline.='%#StatusLineExt#' let l:statusline.="%{strlen(expand('%:e'))?expand('%:e'):expand('%:e')} " endif "}}} let l:statusline.='%*' . l:separator " linter status {{{ if a:isactive " errors let l:statusline .= "%#LinterDashActive#%{(GetLinterStatus('error') == 0?'-':'')}" let l:statusline .= "%#LinterErrorActive#%{(GetLinterStatus('error') == 0?'':GetLinterStatus('error'))}" " style errors let l:statusline .= l:linterdashactive let l:statusline .= "%#LinterDashActive#%{(GetLinterStatus('style_error') == 0?'-':'')}" let l:statusline .= "%#LinterErrorStyleActive#%{(GetLinterStatus('style_error') == 0?'':GetLinterStatus('style_error'))} " " warnings let l:statusline .= "%#LinterDashActive#%{(GetLinterStatus('warning') == 0?'-':'')}" let l:statusline .= "%#LinterWarningActive#%{(GetLinterStatus('warning') == 0?'':GetLinterStatus('warning'))}" " style warnings let l:statusline .= l:linterdashactive let l:statusline .= "%#LinterDashActive#%{(GetLinterStatus('style_warning') == 0?'-':'')}" let l:statusline .= "%#LinterWarningStyleActive#%{(GetLinterStatus('style_warning') == 0?'':GetLinterStatus('style_warning'))} " " info let l:statusline .= "%#LinterDashActive#%{(GetLinterStatus('info') == 0?'-':'')}" let l:statusline .= "%#LinterInfoActive#%{(GetLinterStatus('info') == 0?'':GetLinterStatus('info'))}" else " errors let l:statusline .= "%#LinterDash#%{(GetLinterStatus('error') == 0?'-':'')}" let l:statusline .= "%#LinterError#%{(GetLinterStatus('error') == 0?'':GetLinterStatus('error'))}" " style errors let l:statusline .= l:linterdash let l:statusline .= "%{(GetLinterStatus('style_error') == 0?'-':'')}" let l:statusline .= "%#LinterErrorStyle#%{(GetLinterStatus('style_error') == 0?'':GetLinterStatus('style_error'))} " " warnings let l:statusline .= "%#LinterDash#%{(GetLinterStatus('warning') == 0?'-':'')}" let l:statusline .= "%#LinterWarning#%{(GetLinterStatus('warning') == 0?'':GetLinterStatus('warning'))}" " style warnings let l:statusline .= l:linterdash let l:statusline .= "%{(GetLinterStatus('style_warning') == 0?'-':'')}" let l:statusline .= "%#LinterWarningStyle#%{(GetLinterStatus('style_warning') == 0?'':GetLinterStatus('style_warning'))} " " info let l:statusline .= "%#LinterInfo#%{GetLinterStatus('info') == 0 ? '-' : GetLinterStatus('info')}" endif "}}} let l:statusline .= ' ' . l:separator return l:statusline endfunction "}}} " highlight groups {{{ hi def link StatusLineSeparator Ignore hi def link StatusLineNormal StatusLineNC hi def link StatusLineActive StatusLine hi def link StatusLineNormalNoText TabLineFill hi def link StatusLineActiveNoText TabLineFill hi def link StatusLineNoise StatusLineNormal hi def link StatusLineNoiseActive StatusLineNormal hi def link StatusLineBufferNr StatusLineNormal hi def link StatusLineBufferNrActive StatusLineActive hi def link StatusLinePercent StatusLineNormal hi def link StatusLinePercentActive StatusLineActive hi def link StatusLineLinecount StatusLinePercent hi def link StatusLineLinecountActive StatusLinePercentActive hi DivActive ctermbg=darkgray ctermfg=darkgray guibg=#666666 guifg=#666666 hi DivMod ctermbg=darkred ctermfg=darkred guibg=#660000 guifg=#660000 hi DivModActive ctermbg=red ctermfg=red guibg=#aa0000 guifg=#aa0000 hi DivInput ctermbg=darkblue ctermfg=darkblue guibg=#000022 guifg=#000022 hi def link StatusLineDiv TabLineFill hi def link StatusLineDivActive DivActive hi def link StatusLineDivMod DivMod hi def link StatusLineDivModActive DivModActive hi def link StatusLineDivInput DivInput hi def link StatusLineFileInfo StatusLineActive hi def link StatusLineFile StatusLineNormal hi def link StatusLineFileActive StatusLineActive hi def link StatusLineDir StatusLineFile hi def link StatusLineDirActive StatusLineFileActive hi def link StatusLineDot StatusLineDir hi def link StatusLineDotActive StatusLineDirActive hi def link StatusLineExt StatusLineDir hi def link StatusLineExtActive StatusLineDirActive hi def link StatusLineFileReadOnlyActive WarningMsg hi def link StatusLineWarning StatusLineNormal hi def link StatusLineWarningActive WarningMsg hi def link LinterDash Normal hi def link LinterDashActive Normal hi def link LinterError Normal hi def link LinterErrorActive ErrorMsg hi def link LinterErrorStyle Normal hi def link LinterErrorStyleActive SpellBad hi def link LinterWarning Normal hi def link LinterWarningActive SpellCap hi def link LinterWarningStyle Normal hi def link LinterWarningStyleActive LinterWarningActive hi def link LinterInfo Normal hi def link LinterInfoActive SpellRare "}}} augroup status "{{{ autocmd! autocmd WinNew,WinEnter * setlocal statusline=%!GetStatus(1) autocmd WinLeave * setlocal statusline=%!GetStatus(0) " autocmd WinNew * setlocal statusline=%!GetStatus(1) " autocmd InsertChange * setlocal statusline=%!GetStatus(1) augroup END "}}} "----------------------------------------------------------------------------}}} " #tabline {{{ if exists('+showtabline') " Rename tabs to show tab number. " based on: " http://stackoverflow.com/questions/5927952/whats-implementation-of-vims-default-tabline-function function! MyTabLine() "{{{ let l:customtabline = '' let l:currenttabnum = tabpagenr() let l:lasttabnumber = tabpagenr('$') let l:tabnumber = 1 while l:tabnumber <= l:lasttabnumber let l:buflist = tabpagebuflist(l:tabnumber) let l:winnr = tabpagewinnr(l:tabnumber) if l:lasttabnumber > 1 let l:customtabline .= '%' . l:tabnumber . 'T' let l:customtabline .= (l:tabnumber == l:currenttabnum ? '%1*' : '%2*') let l:customtabline .= (l:tabnumber == l:currenttabnum ? '%#TabLineNumSel#' : '%#TabLineNum#') let l:customtabline .= ' ' . l:tabnumber . ' ' let l:customtabline .= (l:tabnumber == l:currenttabnum ? '%#TabLineItemSel#' : '%#TabLineItem#') endif let l:bufnr = l:buflist[l:winnr - 1] let l:file = bufname(l:bufnr) let l:buftype = getbufvar(l:bufnr, '&buftype') if l:buftype ==# 'help' let l:file = 'help:' . fnamemodify(l:file, ':t:r') elseif l:buftype ==# 'quickfix' let l:file = 'quickfix' elseif l:buftype ==# 'nofile' if l:file =~# '\/.' let l:file = substitute(l:file, '.*\/\ze.', '', '') endif else let l:file = fnamemodify(l:file, ':p:t') endif if l:file ==# '' let l:file = "''" endif let l:customtabline .= l:file . ' ' let l:tabnumber = l:tabnumber + 1 endwhile let l:customtabline .= '%T%#TabLineFill#%=' let l:customtabline .= '%#TabLineItemSel# %{fugitive#statusline()}% ' let l:customtabline .= "%#TabLineItemSel# %{ObsessionStatus(fnamemodify(v:this_session,':t'),'---')} %*" return l:customtabline endfunction "}}} set showtabline=2 set tabline=%!MyTabLine() hi def link TabLineItem TabLine hi def link TabLineItemSel TabLineSel hi def link TabLineNum TabLine hi def link TabLineNumSel TabLineSel endif " exists("+showtabline") "----------------------------------------------------------------------------}}} " vim: set foldmethod=marker: