call pathogen#infect() call pathogen#helptags() call plug#begin('~/.vim/plugged') Plug 'junegunn/vim-easy-align' call plug#end() " Start interactive EasyAlign in visual mode (e.g. vipga) xmap ga (EasyAlign) " Start interactive EasyAlign for a motion/text object (e.g. gaip) nmap ga (EasyAlign filetype plugin indent on " To ignore plugin indent changes, instead use: "filetype plugin on color default "syntax clear syntax on "Seems to fuck up symlinks when set to no... [Debian bug #158657] set backupcopy=yes "Set improve Backspace set backspace=2 "Show the current edition mode on last line, number of column and line set showmode set ruler "Show line numbers set number set laststatus=2 "set rnu "use relative line numbers to cursor function! MyTabLine() let s = '' for i in range(tabpagenr('$')) " select the highlighting if i + 1 == tabpagenr() let s .= '%#TabLineSel#' else let s .= '%#TabLine#' endif " set the tab page number (for mouse clicks) let s .= '%' . (i + 1) . 'T' " the label is made by MyTabLabel() let s .= ' %{MyTabLabel(' . (i + 1) . ')} ' endfor " after the last tab fill with TabLineFill and reset tab page nr let s .= '%#TabLineFill#%T' " right-align the label to close the current tab page "if tabpagenr('$') > 1 " let s .= '%=%#TabLine#%999Xclose' "endif return s endfunction function! MyTabLabel(n) let buflist = tabpagebuflist(a:n) let winnr = tabpagewinnr(a:n) return bufname(buflist[winnr - 1]) endfunction " Show current C function name fun! ShowFuncName() let lnum = line(".") let col = col(".") echohl ModeMsg echo getline(search("^[^ \t#/]\\{2}.*[^:]\s*$", 'bWn')) echohl None call search("\\%" . lnum . "l" . "\\%" . col . "c") endfun "set statusline=%y─┤\ %*%1*%<%f%*\ %2*%M%3*%r%*├%=┤%4*%c%V%*├─┤%4*%l/%L%*├──┤%4*%P%*├─ set statusline=----┤\ %*%1*%<%f%*\ %2*%M%3*%r%*│%Y├%=┤%c%1*%V%*│%l%*%1*/%L%*│%1*%p%%%*├ set tabline=%!MyTabLine() set wildmode=longest,list,full " Set Auto-indentation "set autoindent "set cindent " Make command line X lines high set cmdheight=1 " Highlight search strings set hlsearch " Incremental search set incsearch " No wrap search set nowrapscan " Hide mouse when typing set mousehide " highlighting strings inside C comments let c_comment_strings=1 " Backup dir set autowrite set splitright set splitbelow " default error format "set efm=\"%f\"\\,\ line\ %l:\ error\ %m,\"%f\"\\,\ line\ %l:\ warning\ %m " Dim inactive windows using 'colorcolumn' setting " This tends to slow down redrawing, but is very useful. " Based on https://groups.google.com/d/msg/vim_use/IJU-Vk-QLJE/xz4hjPjCRBUJ " XXX: this will only work with lines containing text (i.e. not '~') "if v:version > 703 "function! s:DimInactiveWindows() " for i in range(1, tabpagewinnr(tabpagenr(), '$')) " let l:range = "" " if i != winnr() " if &wrap " " HACK: when wrapping lines is enabled, we use the maximum number " " of columns getting highlighted. This might get calculated by " " looking for the longest visible line and using a multiple of " " winwidth(). " let l:width=256 " max " else " let l:width=winwidth(i) " endif " let l:range = join(range(1, l:width), ',') " endif " call setwinvar(i, '&colorcolumn', l:range) " endfor "endfunction "augroup DimInactiveWindows " au! " au WinEnter * call s:DimInactiveWindows() "augroup END "endif " " remaps C-j & C-k to C-y and C-e (buffer up/down line-by-line) noremap noremap set nowrap noremap z2l noremap z2h noremap j gj noremap k gk noremap gj j noremap gk k "Macros "nmap mc:%s/[\t ]\+$//'c nmap :make " folding set foldmethod=indent set foldignore= augroup Folding au! autocmd FileType c\|cpp setlocal foldmethod=syntax autocmd FileType mail setlocal foldmethod=expr autocmd FileType mail setlocal foldexpr=(strlen(substitute(matchstr(getline(v:lnum),\"^\ *[>\ ]*\"),\"\ *\",\"\",\"g\"))) augroup END set foldminlines=0 set foldcolumn=0 set foldlevel=999 augroup Lilo au! autocmd BufEnter */etc/lilo* set syntax=lilo augroup END augroup Jenkinsfile au! autocmd BufEnter */Jenkinsfile set ft=Jenkinsfile augroup END " Quick search for merges nmap /^\(<\{7\}\\|>\{7\}\\|=\{7\}\) nmap :windo set invrelativenumber "nmap :setlocal foldcolumn-=1:execute 'setlocal foldlevel='.(&foldcolumn - 2) "nmap :setlocal foldcolumn+=1:execute 'setlocal foldlevel='.(&foldcolumn - 2) "nmap :windo set foldcolumn-=1 "nmap :windo set foldcolumn+=1 nmap :set textwidth-=1\|set tw() nmap :set textwidth=80\|set tw nmap :set textwidth+=1\|set tw " open all "nmap zR " close all "nmap zM " open/close under cursor nmap ; za " open/close recursive under cursor "nmap zA "nmap :windo set invfoldenable nmap :set invet nmap :echo "hi<" . synIDattr(synID(line("."),col("."),1),"name") . '> trans<' \ . synIDattr(synID(line("."),col("."),0),"name") . "> lo<" \ . synIDattr(synIDtrans(synID(line("."),col("."),1)),"name") . ">" "buffer moving nmap h :tabN nmap j :bn nmap k :bN nmap l :tabn augroup Skeleton au! " read in skeleton files autocmd BufNewFile *.* silent! 0r ~/.vim/skel/%:e autocmd BufNewFile * silent! %substitute#<+\(.\{-\}\)+>#\=eval(submatch(1))#ge " get to cursor position autocmd BufNewFile * silent! %substitute#<=CURSOR=>##g augroup END augroup Load au! " When editing a file, always jump to the last known cursor position. " Don't do it when the position is invalid or when inside an event handler " (happens when dropping a file on gvim). autocmd BufReadPost * \ if line("'\"") > 0 && line("'\"") <= line("$") | \ exe "normal g`\"" | \ exe "normal zz" | \ endif augroup END function! CscopeSearch(csearch) let @/=a:csearch set hls let l:prompt = "Rechercher '".a:csearch."' avec cscope [acdefgist] : " echo l:prompt let l:ctype=nr2char(getchar()) redraw echo l:prompt.l:ctype." " return 'set hls | cscope find '.l:ctype.' '.a:csearch endfunction function! LoadTags() " Load local cscope db if exists if filereadable( expand("$PWD/tags") ) set tags=tags elseif filereadable( expand("$PWD/ctags.out") ) set tags=$pwd/ctags.out elseif has("cscope") set cst if filereadable( expand("$PWD/cscope.out") ) cscope add $PWD/cscope.out endif let l:git = system("dirname $(git rev-parse --git-dir) | tr -d '\n'") if filereadable ( l:git . '/cscope.out' ) && l:git != expand("$PWD") exe 'cscope add ' . l:git . ' ' . l:git endif " cscope macros nmap C :!cscope -bqu:cs reset nmap c :execute CscopeSearch(expand("")) " search definitions of word under cursor nmap g :cs find g nmap S :cs find s " search file under cursor "nmap f :execute CscopeSearch(expand("")) nmap F :execute CscopeSearch(expand("")) nmap f :cs find f " search current file nmap % :execute CscopeSearch(expand("%:t")) "nmap % :cs find i %:t nmap r :execute CscopeSearch(input("Rechercher : ")) endif endfunction call LoadTags() augroup WhiteSpaces "set list listchars=tab:├─>,precedes:◂,extends:▸,nbsp:␣,space:·,trail:• set list listchars=tab:│ ,precedes:…,extends:▸,nbsp:␣,space:· set fillchars=vert:│,stl:─,stlnc:─,fold:─,diff:x nmap :set invlist " F*cking whitespaces function! HighLightExtraSpacesAndColumns() highlight ExtraWhitespace ctermbg=160 ctermfg=none guibg=red match ExtraWhitespace /\s\+$\| \+\ze\t/ if &textwidth != 0 execute 'match ExtraWhitespace /\s\+$\| \+\ze\t\|\%>'.&textwidth.'v.\+/' endif endfunction autocmd BufRead * call HighLightExtraSpacesAndColumns() autocmd WinEnter * call HighLightExtraSpacesAndColumns() autocmd OptionSet textwidth call HighLightExtraSpacesAndColumns() "Don’t overwrite the whitespaces colors on cursor line… autocmd BufRead * call matchadd('SpecialKey', '\s\+', -1) autocmd WinEnter * call matchadd('SpecialKey', '\s\+', -1) augroup END set colorcolumn=+1 hi colorcolumn ctermbg=none ctermfg=238 cterm=bold,underline set title set autoindent set diffopt=iwhite,filler,vertical " mouse " v -> enabled in visual mode " i -> enabled in insert mode " c -> enabled in command mode " a -> enabled in all modes set mouse=a set mousem=extend set tabstop=4 set softtabstop=0 set shiftwidth=4 set noexpandtab set copyindent set nopreserveindent set smarttab let g:detectindent_preferred_expandtab = 0 let g:detectindent_preferred_indent = 4 let g:detectindent_preferred_when_mixed = 1 augroup DetectIndentation autocmd BufRead * DetectIndent augroup END " Draws underline (waits for char input) noremap U yyp0$r set ttimeoutlen=0 set timeoutlen=250 " Code comment/uncomment noremap // m"I// g`"3l noremap /* m"I/* A */jg`"3l " xmap // /* xnoremap // `>o#endif` xnoremap /* `>a */` noremap \* m"e?/\* xxx/ \*\/xxx:nohljg`"3h noremap \\ m"0:s:// *::\|:nohlg`"3h noremap / :NERDTreeToggle " You can use other keymappings like instead of if you want to " use these mappings as default search and somtimes want to move cursor with " EasyMotion. function! s:incsearch_config(...) abort return incsearch#util#deepextend(deepcopy({ \ 'modules': [incsearch#config#easymotion#module({'overwin': 1})], \ 'keymap': { \ "\": '(easymotion)' \ }, \ 'is_expr': 0 \ }), get(a:, 1, {})) endfunction noremap / incsearch#go(incsearch_config()) noremap ? incsearch#go(incsearch_config({'command': '?'})) noremap g/ incsearch#go(incsearch_config({'is_stay': 1})) " FuzzyFinder map ff :FufFile map fd :FufDir map fb :FufBuffer map ft :FufTagWithCursorWord! let g:EasyMotion_do_mapping = 0 " Disable default mappings let mapleader=" " " Jump to anywhere you want with minimal keystrokes, with just one key binding. " `s{char}{label}` nmap (easymotion-overwin-f) " or " `s{char}{char}{label}` " Need one more keystroke, but on average, it may be more comfortable. nmap (easymotion-overwin-f2) " Turn off case insensitive feature let g:EasyMotion_smartcase = 0 " JK motions: Line motions map j (easymotion-j) map k (easymotion-k) " Reformatting is done using 'gq' noremap Q :s/^/> / noremap q :s/^[ ]*>[ ]*// noremap u :noh runtime! ftplugin/man.vim noremap K :Man =expand("") let g:ft_man_open_mode = 'vert' " Function " Erase_Sig_but_Your() " " Author " Yann Kerhervé " Based on Luc Hermitte work " " Purpose " Deletes signatures at the end of e-mail replies. But keep " your sig intact (mutt-added). " Also deletes the empty lines (even those beginning by '>') " preceding the signature. " function! Erase_Sig_but_Your() " Search for the signature pattern : "^> -- $" let lastline = line ('$') let i = lastline " (1) while i >= 1 if getline(i) =~ '^> *-- $' break endif let i = i - 1 endwhile " let find the beginning of our sig let j = i while j < lastline let j = j + 1 if getline(j) =~ '^-- $' let j = j - 1 break endif endwhile " If (1) found, then if i != 0 " First, search for the last non empty (non sig) line while i >= 1 let i = i - 1 " rem : i can't value 1 if getline(i) !~ '^(>s*)*$' break endif endwhile " Second, delete these lines plus the signature let i = i + 1 exe 'normal '.i.'Gd'.j.'G' endif endfunction function! GitBlameCurrentLine() let l:line = line('.') let l:file = expand("%:t") let l:wd = expand("%:p:h") let content = system("cd " . l:wd . ";git blame -L ". l:line . "," . l:line . " " . l:file . " | sed 's/).*/)/'") let line = split(content, '\n')[0] echohl WarningMsg | echo line | echohl None endfunction command! GitBlameCurrentLine :call GitBlameCurrentLine() noremap b :GitBlameCurrentLine augroup MailEditor au! " Highlights columns 77-80 and 81+ autocmd BufRead /tmp/mutt-*[0-9] let w:m1=matchadd('Search', '\%>77v,\+', -1) autocmd BufRead /tmp/mutt-*[0-9] let w:m2=matchadd('ErrorMsg', '\%>81v,\+', -1) " n goto next empty reply-to paragraph " m opens an empty reply-paragraph at this line " d deletes everything until but the signature " w reformats entire mail but the signature " D deletes everything until but the previous reply-to § autocmd FileType mail noremap n /^> $ autocmd FileType mail noremap D ^d?^\([^>]\\|$\)?+O autocmd FileType mail noremap d ^d/^-- $O autocmd FileType mail noremap w ggv/^-- $:!par rTbgqRe 'B=.,?_A_a' 'Q=_s>\|' set spelllang=fr,en,de autocmd FileType mail setlocal spell autocmd FileType mail setlocal textwidth=74 autocmd FileType mail execute Erase_Sig_but_Your() autocmd FileType mail :normal ,n augroup END noremap zc z=1 "function! SetPythonTabs(tabsize) " execute 'setlocal tabstop=' . a:tabsize " execute 'setlocal softtabstop=' . a:tabsize " execute 'setlocal shiftwidth=' . a:tabsize " setlocal smarttab " setlocal expandtab "endfunction "" "" DafUq ? ""-------- "augroup Tabs " au! " autocmd FileType python execute SetPythonTabs(4) "augroup END " augroup CursorLine au! " when switching between buffers autocmd BufEnter * set cursorline autocmd BufLeave * set nocursorline " when switching between windows autocmd WinEnter * set cursorline autocmd WinLeave * set nocursorline " doesn’t seem to work on urxvt :( autocmd FocusLost * set nocursorline autocmd FocusGained * set cursorline augroup END " footnotes noremap ,, :call VimFootnotes() noremap ,. :exe b:pos function! VimFootnotes() if exists("b:vimfootnotenumber") let b:vimfootnotenumber = b:vimfootnotenumber + 1 let cr = "" else let b:vimfootnotenumber = 1 let cr = "\" endif let b:pos = line('.').' | normal! '.virtcol('.').'|'.'4l' exe "normal a[".b:vimfootnotenumber."]\G" if search("-- $", "b") exe "normal O".cr."[".b:vimfootnotenumber."] " else exe "normal o".cr."[".b:vimfootnotenumber."] " endif startinsert! endfunction augroup Todo au! autocmd FileType vimwiki set syn=todo augroup END augroup PyMode let g:pymode_lint_on_fly = 1 let g:pymode_lint_unmodified = 1 let g:pymode_rope = 1 let g:pymode_rope_complete_on_dot = 0 autocmd FileType * set signcolumn=auto autocmd FileType python set signcolumn=yes autocmd FileType python sign define PymodeC texthl=Number augroup END augroup FuckingShit autocmd BufEnter defs.* set ft=make autocmd BufEnter rules.* set ft=make augroup END augroup Syntastic_And_Tsuquyomi let g:syntastic_always_populate_loc_list = 1 let g:syntastic_auto_loc_list = 1 let g:syntastic_check_on_open = 1 let g:syntastic_check_on_wq = 1 " Tsuquyomi-powered let g:tsuquyomi_disable_quickfix = 1 let g:syntastic_typescript_checkers = ['tsuquyomi'] augroup END