-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvimrc
979 lines (824 loc) · 30.9 KB
/
vimrc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
"{{{ README: PREREQUESITES
"-------------------------------------------------------------------------------
" For maximum ease while reading this file in Vim, if sections don't appear
" please enter this command:
" :set foldmethod=marker
"
" NOTE: Avoid mapping keys like CTRL and TAB, it's a little tricky, as the
" keys are first catched by the terminal emulator when Vim is used in CLI.
"}}}
"{{{ General settings
"-------------------------------------------------------------------------------
" Enhance supported features in Vim by dropping Vi compatibility.
" When used for system-wide configuration, the vimrc file will ALWAYS be
" read in 'compatible' mode. This mode will produce some errors in this
" current configuration as unfound features or functions.
" See :help system-vimrc for more details.
set nocompatible
" Disable the modeline usage, preventing vimscript code that could be
" malicious to be executed see
" http://lists.alioth.debian.org/pipermail/pkg-vim-maintainers/2007-June/004020.html
" Modeline is a Vim feature allowing to define Vim parameters for a specific
" file at the first or at the last lines of that file.
set modelines=0
" Define the <Leader> key in replacement of the default one \
let mapleader = ","
" Define <Leader> key mapping local to a buffer (depending on the filetype for
" example).
let maplocalleader = ";"
" Enable the mouse usage only in Vim normal mode, as we want still to use the
" selection managed by the terminal when Vim is in insert mode.
if has("mouse")
set mouse=n
endif
" Use UTF-8 encoding in file and avoid ^B and strange characters appearing
" in the statusline when used with vim-powerline plugin.
set encoding=utf-8
" Switch to hexadecimal mode
function! s:HexadecimalModeToggle()
if exists("b:bin") && b:bin
let b:bin = 0
" Use the external binary editor "xxd" which comes bundled with Vim.
silent execute "%!xxd -r"
echo "Hexadecimal mode disabled for \"" . expand("%:p") . "\""
else
let b:bin = 1
silent execute "%!xxd"
echo "Hexadecimal mode enabled for \"" . expand("%:p") . "\""
endif
endfunction
nnoremap <leader>sh :call <SID>HexadecimalModeToggle()<cr>
" if has("autocmd")
" augroup HexEditing
" augroup!
"
"
" augroup END
" endif
" Enable spell checking only for C, C++ and Tex files
if has("autocmd")
augroup spellChecking
autocmd!
autocmd FileType c,cpp,tex setlocal spell
augroup end
endif
" Automatically save before commands like :next and :make
"set autowrite
" Hide buffers when they are abandoned, instead of unloading them (use much
" memory space).
"set hidden
" Convert the current word to lowercase in insert mode
inoremap <c-l> <esc>mqviwu`qa
" Convert the current word to UPPERCASE in insert mode
inoremap <c-u> <esc>mqviwU`qa
" Surround a word with "
nnoremap <leader>" mqviw<esc>bi"<esc>ea"<esc>`ql
" Surround a word with '
nnoremap <leader>' mqviw<esc>bi'<esc>ea'<esc>`ql
" Surround a visual block with "
vnoremap <leader>" mq<esc>`<i"<esc>`>a"<esc>`q
" Paste from X clipboard.
" NOTE: Don't map this key in normal mode as CTRL-V is used for vertical
" selection.
inoremap <silent><c-v> <esc>"+pi
" Copy to X clipboard.
inoremap <silent><c-c> <esc>"+yi
" Reselect the text that was just pasted.
nnoremap <leader>v V`]
" Save automatically the file when losing focus.
augroup saveOnFocusLost
autocmd!
autocmd FocusLost * silent! wa
augroup end
"}}}
"{{{ Plugins management
"-------------------------------------------------------------------------------
" Get system vimrc location.
function GetSystemVimRcLocation()
redir => l:version
silent version
redir END
let l:i = 0
let l:j = 0
let l:word = ''
let l:location = ''
let l:splitted = split(l:version)
for l:word in l:splitted
if l:word =~ ':'
let l:j += 1
" The fourth colon the :version command will display if the one
" from the system vimrc location.
if l:j == 4
let l:location = get(l:splitted, l:i + 1)
" Remove quotes
let l:location = strpart(l:location, 1)
let l:location = strpart(l:location, 0, strlen(l:location) - 1)
" Expand the location if the latter uses environment variables
" e.g. $VIM/vimrc.
let l:location = expand(l:location)
break
endif
endif
let l:i += 1
endfor
return expand(l:location)
endfunction
function GetSystemWideLocation()
" If the folder has already a vim subfolder, don't need to add one
" again.
if fnamemodify(GetSystemVimRcLocation(), ":p:h") =~ "vim"
return fnamemodify(GetSystemVimRcLocation(), ":p:h")
else
return fnamemodify(GetSystemVimRcLocation(), ":p:h") . "/vim"
endif
endfunction
function IsRunningAsRoot()
" We cannot use the $USER environnment variable. Indeed, when running su
" from a standard user, the $USER will still display the standard username
" while we have root permissions. Using su - is the solution since the
" dash ask to have a login shell which ask to flush then reload all
" environment variables.
" if expand($USER) == "root"
if !executable("whoami")
echoerr "Unable to find the whoami command in your PATH environment variable."
exit
endif
let l:username = split(system("whoami"))
if l:username[0] == "root"
return 1
endif
endfunction
function HasSystemWideConfiguration()
if filereadable(GetSystemVimRcLocation())
return 1
endif
endfunction
function IsVundleInstalled()
if filereadable(fnamemodify($MYVIMRC, ":p:h") . "/.vim/bundle/vundle/README.md")
return 1
endif
if filereadable(GetSystemWideLocation() . "/bundle/vundle/README.md")
return 2
endif
endfunction
if !IsVundleInstalled()
" NOTE: In the following line, the user configuration always take
" precedence over the system-wide configuration if any.
if !executable("git")
" echoerr does NOT abord sourcing if it is used. The followings line until the
" end of the file will still be executedV
echoerr "Git isn't installed on this system or cannot be found via the PATH variable."
exit
endif
" If we have a system wide configuration, and we are running as root,
" install Vundle as systemwide, otherwise, install vundle as simple user.
if HasSystemWideConfiguration() && IsRunningAsRoot()
let s:location = GetSystemWideLocation() . "/bundle"
else
let s:location = expand($HOME) . "/vim/bundle"
endif
echo "Installing vundle into " . s:location
" The default permission used by mkdir() is 755
call mkdir("s:location", "p")
" Make sure the folder has been really created. It could fail.
if !isdirectory("s:location")
echoerr "Creating " . s:location . " has failed. Make sure you have permissions."
exit
endif
execute "silent !git clone https://github.com/gmarik/vundle " . s:location . "/vundle"
let s:vundleFirstInstall = 1
endif
filetype off
" Add Vundle to the runtimepath
if IsVundleInstalled() == 1
set runtimepath+=~/.vim/bundle/vundle
elseif IsVundleInstalled() == 2
execute "set runtimepath+=" . GetSystemWideLocation() . "/bundle/vundle"
endif
" If you don't like the directory name 'bundle', you can pass a different
" name as an argument: call vundle#rc('~/src/vim/bundle')
call vundle#rc()
" Mandatory, let's manage vundle by vundle.
" NOTE: Comments after Bundle command are not allowed.
Bundle 'gmarik/vundle'
" Plugins
Bundle 'nanotech/jellybeans.vim'
Bundle 'tomasr/molokai'
Bundle 'bling/vim-airline'
Bundle 'Valloric/YouCompleteMe'
Bundle 'SirVer/ultisnips'
Bundle 'honza/vim-snippets'
Bundle 'tomtom/tcomment_vim'
Bundle 'tpope/vim-markdown'
Bundle 'junegunn/seoul256.vim'
Bundle 'osyo-manga/vim-over'
Bundle 'chikamichi/mediawiki.vim'
Bundle 'git://git.code.sf.net/p/vim-latex/vim-latex'
" Required
filetype plugin indent on
" Install plugins.
if exists("s:vundleFirstInstall")
echo "Installing all your plugins..."
BundleInstall()
" For other commands:
" :BundleList - list configured bundles
" :BundleInstall(!) - install(update) bundles
" :BundleSearch(!) foo - search(or refresh cache first) for foo
" :BundleClean(!) - confirm(or auto-approve) removal of unused bundles
"
" see :h vundle for more details or wiki for FAQ
endif
"}}}
"{{{ Positions and movements
"-------------------------------------------------------------------------------
" Force ourself to use the right way to use Vim by leaving the insert mode
" asap we can.
" noremap <Up> <nop>
" noremap <Down> <nop>
" noremap <Right> <nop>
" noremap <Left> <nop>
" <Ctrl> + motion operator to move around through wrapped lines. When soft
" wrapping is enabled, each lines of the file splits accross several display
" lines in order to don't need to scroll horizontally to see all the text.
nnoremap <C-j> gj
nnoremap <C-k> gk
vnoremap <C-j> gj
vnoremap <C-k> gk
nnoremap <C-Down> gj
nnoremap <C-Up> gk
vnoremap <C-Down> gj
vnoremap <C-Up> gk
nnoremap <C-$> g$
nnoremap <C-0> g0
vnoremap <C-$> g$
vnoremap <C-0> g0
" Jump to the last position when reopening a file.
if has("autocmd")
function! s:LastFilePosition()
if line("'\"") > 1 && line("'\"") <= line("$")
execute "normal! g'\""
endif
endfunction
augroup lastPosition
autocmd!
autocmd BufReadPost * :call <SID>LastFilePosition()
augroup end
endif
" Briefly jump to the matching bracket (only when it is visible).
"set showmatch
" Use <tab> instead of % in order to key match brackets pairs.
nnoremap <tab> %
vnoremap <tab> %
" NOTE: For mnemonic, the operator abbreviation names are set as "Inside Next
" Parentheses".
"
" Visually select text around last parentheses.
onoremap ip) :<c-u>normal! F)vi(<cr>
" Visually select text around next parentheses.
onoremap in( :<c-u>normal! F(vi)<cr>
" Visually select text around last bracket.
onoremap ip{ :<c-u>normal! F}vi{<cr>
" Visually select text around next bracket.
onoremap in{ :<c-u>normal! F{vi}<cr>
"}}}
"{{{ Appearance
"-------------------------------------------------------------------------------
" Disable intro message appearing when starting Vim
set shortmess+=I
" Wrap long line of text, avoiding the wrapping to misbehave when unprintable
" characters are made visible with the 'list' command.
set wrap
" Get the break at a word boundary
set linebreak
" Displaying all characters must be disabled in order for the wrapping to work
" properly.
set nolist
" When line numbers are disabled, display a character indicating that the line
" is currently soft wrapped.
set showbreak=…
" Format automatically paragraphs everytime text is inserted or deleted. As
" this command is really annoying when writing code, use gqip to reformat the
" paragraph instead.
" set formatoptions=a
" Only apply reformat on comments to avoid the code to become broken.
set formatoptions+=c
" Automatically insert the current comment leader after hitting 'o' or 'O' in
" normal mode.
set formatoptions+=o
" Allow formatting of comments with "gq".
set formatoptions+=q
" Recognize automatically number lists and format them.
set formatoptions+=n
" Don't break a line after a one letter word
set formatoptions+=1
" Keep at least 3 lines above and below the cursor
set scrolloff=3
" Enable syntax highlighting
if has("syntax")
syntax on
endif
" Highlight the line where the cursor is currently on.
if has("syntax")
set cursorline
endif
" <Leader> + r : replace all ^M with normal linebreak.
nnoremap <leader>r<cr> :%s/<C-V><C-M>/<C-V><C-M>/g<cr>
" <Leader> + d : delete the additional linebreak induced by Windows/DOS style.
nnoremap <leader>d<cr> :%s/<C-V><C-M>//g<cr>
" Set number in all modes.
set number
" Set relative number in insert mode.
if has("autocmd")
augroup relativeNumberInInsertMode
autocmd!
autocmd InsertEnter * :setlocal relativenumber
autocmd InsertLeave * :setlocal norelativenumber
augroup end
endif
" <Leader> + n to toggle the line numbers for the current local buffer.
function! s:NumberToggle()
if &number
set nonumber
echo "Line numbers disabled for \"" . expand("%:p") . "\""
else
set number
echo "Line numbers enabled for \"" . expand("%:p") . "\""
endif
endfunction
nnoremap <leader>n :call <SID>NumberToggle()<cr>
" <Leader> + r + n to toggle the relative line numbers for the local buffer.
function! s:RelativeNumberToggle()
if &relativenumber
set norelativenumber
echo "Relative numbers disabled for \"" . expand("%:p") . "\""
else
set relativenumber
echo "Relative numbers enabled for \"" . expand("%:p") . "\""
endif
endfunction
nnoremap <leader>rn :call <SID>RelativeNumberToggle()<cr>
"<Leader> + f to toggle the column incating the the scope of the folds.
function! s:FoldColumnToggle()
if &foldcolumn
setlocal foldcolumn=0
echo "Fold column disabled for \"" . @% . "\""
else
setlocal foldcolumn=4
echo "Fold column enabled for \"" . @% . "\""
endif
endfunction
nnoremap <silent><leader>f :call <SID>FoldColumnToggle()<cr>
" Reduce the scope of the syntax highlight, which prevents Vim to hang
" terribly when syntax highlight is used on very long lines.
if has("syntax") && has("autocmd")
function! s:GetMaxLength()
return max(map(range(1, line('$')), "col([v:val, '$'])")) - 1
endfunction
function! s:ReduceHighlightScope()
if s:GetMaxLength() ># (&columns * 3)
execute "set synmaxcol=" . (&columns * 3)
endif
endfunction
augroup ReduceHighlightScope
autocmd!
autocmd BufReadPost,VimResized * :call <SID>ReduceHighlightScope()
augroup end
endif
" Set a colorscheme
if has("syntax")
try
let s:definedColorscheme = "jellybeans"
execute "colorscheme " . s:definedColorscheme
catch /^Vim(\a\+):E185:/
echo v:throwpoint
echo 'The colorscheme "' . s:definedColorscheme . '" doesn''t exist, using the default one instead.'
endtry
" If using a dark background within the editing area and syntax highlighting
" turn on this option as well, and forces the colorcheme to be adapted
" set background=dark
endif
" Override the default Monospace font when GUI is running and sets its size to
" 10.
if has('gui_running')
set guifont=Droid\ Sans\ Mono\ for\ Powerline\ 10
endif
" FIXME: terminal color hardcode shoun't be!
set t_Co=256
" Display information into the bottom line
if has("statusline")
let g:airline_symbols = {}
" unicode symbols
let g:airline_left_sep = '»'
let g:airline_left_sep = '▶'
let g:airline_right_sep = '«'
let g:airline_right_sep = '◀'
let g:airline_symbols.linenr = '␊'
let g:airline_symbols.linenr = ''
let g:airline_symbols.linenr = '¶'
let g:airline_symbols.branch = '⎇'
let g:airline_symbols.paste = 'ρ'
let g:airline_symbols.paste = 'Þ'
let g:airline_symbols.paste = '∥'
let g:airline_symbols.whitespace = 'Ξ'
" powerline symbols
let g:airline_left_sep = ''
let g:airline_left_alt_sep = ''
let g:airline_right_sep = ''
let g:airline_right_alt_sep = ''
let g:airline_symbols.branch = ''
let g:airline_symbols.readonly = ''
let g:airline_symbols.linenr = ''
" IMPROVE: Try to detect Powerline plugin as g:powerline_enabled doesn't exist
" in this namespace
" FIXME: Doesn't work if system-wide Vim configuration used
if filereadable(expand("$HOME/.vim/bundle/powerline/plugin/Powerline.vim"))
" FIXME: Check xterm-256color
"if &t_Co < 256
" Explicitly tell Vim we are using a 88/256 color terminal
" set t_Co=256
" let g:Powerline_loaded = 0
"endif
" Define the symbols and deviders set.
" Fancy uses custom icons and arrows which requires a patched font.
let g:Powerline_symbols = 'fancy'
else
" Emulate the standard status enabled with command 'set ruler'
" set statusline=%< " Where to truncate line if too long
" set statusline+=%f " Path to the buffer file
" set statusline+=\ " Add a space (have to be scaped)
" set statusline+=%h " Add [help] flag is help file
" set statusline+=%m " Add [+] (modified) flag is the file has been modified or
" " [-] if the file is unmodifiable
" set statusline+=%r " Add [RO] flag if the file is read only
" set statusline+=%= " Switch to the right side
" set statusline+=%-14.(%04l/%O4L,%c%V%)
" " () -> Add a new item group aligned with a 14 right padding
" " %l -> Line number
" " %c -> column number
" " %V -> Vertical column number (assumes tabulations are spaces)
" set statusline+=\ %P " Space with the percentage of displayed file
endif
" Always display a status line
set laststatus=2
endif
" Displays a line at char 80 and colorizes text that goes beyong this value
" FIXME: Only display this line when text goes beyond it.
" if has('syntax')
" set colorcolumn=79
" highlight link OverLength ColorColumn
" execute 'match OverLength /\%'.&cc.'v.\+/'
" endif
" FIXME: Strip all trailing whitespaces in the current file
"nnoremap <leader>W :%s/\s\+$//<cr>:let @/=''<cr>:echo 'Trailing whitespaces
"removed for ' . expand("%")<cr>
" Add a completion menu when invoking autocompletion in the Vim cmd line
"set wildmenu
" <Leader> + <space> : show invisible characters.
function! s:ToggleInvisibleCharacters()
if &l:list
set nolist
echo "Invisible characters have been hidden for \"" . expand("%") . "\"."
else
set list
set listchars=tab:▸\ ,eol:¬
echo "Invisible characters have been shown for \"" . expand("%") . "\"."
endif
endfunction
nnoremap <leader><space> :call <SID>ToggleInvisibleCharacters()<cr>
"}}}
"{{{ Autocompletion
"-------------------------------------------------------------------------------
" Avoid YouCompleteMe conflicts with default UltiSnips key mappings.
let g:UltiSnipsExpandTrigger="<CR>"
let g:UltiSnipsJumpForwardTrigger="<tab>"
" Add location of the dictionary word completion
if filereadable("/usr/share/dict/words")
set dictionary+=/usr/share/dict/words
endif
" Disable preview scratch window appearing on completion
set completeopt=menu,menuone,longest
" Set the maximum number of items to be displayed show in the popup menu
if has("insert_expand")
set pumheight=15
endif
"}}}
"{{{ Indentation
"-------------------------------------------------------------------------------
" Load indentation rules and plugins according to the detected filetype
if has("autocmd")
filetype plugin indent on
endif
" Use backspace to remove these kinds of content
set backspace=indent,eol,start
" Specifies the width of a tab character
set tabstop=4
" Remove the 4 characters when using backspace. This option prevails when
" expandtab isn't enabled.
" ex.: tabstop = 8
" softtabstop = 4
" shiftwidth = 4
" noexpand
" Using tab and indentation in this configuration will use 4 characters, but
" when pressing tab another time directly, the 4 chars are replaced by a tab
" of 8 chars length. If tabstop equals 4 too, then always tabs will be added.
set softtabstop=4
" Replace tab by spaces
set expandtab
" Use 4 space characters when using automatic indentation (with autoindent) or
" manually with > or < keys.
set shiftwidth=4
" Use the same indent as the previous indented line
set autoindent
" Add markers folds for Vim and Bash/sh files
if has("folding")
augroup filetype_vim
autocmd!
autocmd FileType vim,sh setlocal foldmethod=marker foldlevelstart=0
augroup end
endif
"}}}
"{{{ Search options
"-------------------------------------------------------------------------------
" When searching, this option allows you to jump to the beginning of the file,
" when the end is reached.
set wrapscan
" Ignore the case in search patterns (needed by 'smartcase')
set ignorecase
" Enable case-insensitive search when the search is all-lowercase, but if one
" or more characters is uppercase the search will be case-sensitive.
set smartcase
if has("extra_search")
" Show the result location when typing a pattern to search. Pressing return
" goes to the result location while typing Esc to back to the original
" position.
set incsearch
" Briefly jump to the matching bracket is it it visible on the same screen
set showmatch
" Toggle the search highlight feature. When you get bored looking at the
" highlighted matches, toggle the search highlight feature off. This does
" not change the option value, as soon as you use a search command,
" the highlighting comes back.
set hlsearch
nnoremap <leader>/ :call <SID>HlsearchToggle()<cr>
function! s:HlsearchToggle()
if &l:hlsearch
set nohlsearch
echo "Highlighted matches disabled."
else
set hlsearch
echo "Previous matches highlighted."
endif
endfunction
endif
" Opens help vertically
noremap <leader><F1> :vertical rightbelow help<cr>
" Get ready to look for an item in help
nnoremap <F1> :help
" Search for text in the whole help
nnoremap <leader>g<F1> :helpgrep
" Get rid of crappy regex Vim handling and use normal regexes instead
nnoremap / /\v
vnoremap / /\v
" Search inside the selected scope with /
vnoremap / <Esc>/\%V
" Highlight the trailing whitespaces as an error
nnoremap <silent><leader>w :match Error /\v $/<cr> :echo "Trailing whitespaces marked as error."<cr>
nnoremap <silent><leader>W :match none<cr>
" Next occurrence when using :helpgrep
nnoremap <silent><c-n> :cn<cr>
" Use grep to search for the current word under the cursor
nnoremap <leader>g :silent execute 'grep! -R ' . shellescape(expand("<cword>")) . ' .'<cr>:copen<cr>:redraw!<cr>
nnoremap <leader>G :call GrepOperator("up")<cr>
function! GrepOperator(...)
let word = "shellescape(expand(\"<cword>\"))"
if a:000[0] ==# "up"
let l:word = "shellescape(expand("<cWORD>"))"
echom word
endif
execute 'grep! -R ' . word . ' .'
redraw!
copen
endfunction
" }}}
"{{{ Sessions management
"-------------------------------------------------------------------------------
" The following functions will save your settings (see :help :mksession) on Vim
" exit, and load those settings when you enter Vim again from the same folder.
" Check if the needed Vim features are present and define session files and
" paths names again as buffer variables are wiped out when restoring a vim
" session
function! s:DefineSessionPath()
if !has("mksession")
echoerr "Vim wasn't compiled with +mksession feature: Vim sessions not supported."'
elseif !has("file_in_path")
echoerr "Vim wasn't compiled with +find_in_path feature: Vim sessions are supported only manually with :mksession command, but not with the shortcuts defined in this vimrc."'
else
let b:sessionDefaultDir = $HOME . "/.vim/sessions"
let b:sessionDir = b:sessionDefaultDir . getcwd()
let b:sessionFile = b:sessionDir . "/session.vim"
return 1
endif
endfunction
" Creates a session
nnoremap <silent><leader>ms :call <SID>MakeSession()<cr>
function! s:MakeSession()
if !<SID>DefineSessionPath()
return
endif
" Hereafter we have to use strlen() as finddir and findfile functions
" return the path or file found.
" If the directory doesn't already exists, create it
if !strlen(findfile(b:sessionDir))
call mkdir(b:sessionDir, "p")
redraw
else " The firectory already exists as a file
echoerr "The directory " . b:sessionFile . " can't have the same name as the file \"" . b:sessionFile . "\" used to save your Vim session!\nPLease rename your folder or manually use :mksession.\n"
return 0
endif
" Now we are sure the directory is created, check if we can write to it
if filewritable(b:sessionDir) != 2
echoerr "The session directory \"" . b:sessionDir . "\" is not writable, please fix file permissions!\nUnable to create your session file.\n"
return 0
endif
" Check if the session file isn't a directory
if strlen(finddir(b:sessionFile))
echoerr "The session \"" . b:sessionFile . "\" is already a directory: please remove it."
return 0
endif
" If the session file already exists
if strlen(findfile(b:sessionFile))
" The session file is writable
if filewritable(b:sessionFile)
execute "mksession! " . b:sessionFile
echo "The session \"" . b:sessionFile . "\" has been updated."
else " The session file isn't writable
echoerr "The session \"" b:sessionFile "\" already exists but can''t be written.\nPlease check your the write persissions for this file (see umask)."
return 0
endif
" If the session file doesn't exist, create it
else
" Prevent the global variable to be saved in the session file
if exists("g:sessionLoaded")
unlet g:sessionLoaded
endif
execute "mksession! " . b:sessionFile
echo "The session \"" . b:sessionFile . "\" has been created"
" Recreate the variable as we are using a Vim session
let g:sessionLoaded = 1
endif
" The session file has been successfully created, but isn't readable
if !filereadable(b:sessionFile)
echohl WarningMsg
echo "but you won't be able to read it back in Vim as the file isn't readable. Please check your file permissions (see umask)."
echohl None
else
echon "."
endif
endfunction
" On Vim exit, if a session is currently used, ask the user if he wants to
" update it.
" NOTE: Don't automatically update the session on Vim exit, otherwise the
" project session from current directory will be replaced with the current
" opened file(s). This behavior is unwanted.
if has("autocmd")
" Update session when leaving Vim
augroup UpdateSession
autocmd!
" autocmd VimLeave * :call <SID>UpdateSession()<cr>
augroup end
endif
function! s:UpdateSession()
if !<SID>DefineSessionPath()
return
endif
if strlen(findfile(b:sessionFile))
if exists("g:sessionLoaded")
let l:choice = 1
while l:choice != 1
echohl ErrorMsg
let l:choice = confirm("You are using a session for this directory.\nDo you want to update it with the current one?", "&Yes\n&No", 1)
echohl None
if choice == 1
wall " Saves all modifications
call <SID>MakeSession()
else
let l:choice = confirm("Are you sure you want to leave without saving changes?", "&Yes\n&No", 2)
if l:choice == 1
let l:choice = 0
endif
endif
endwhile
endif
endif
endfunction
" Quit all buffers and exit Vim
nnoremap <silent>SQ :call <SID>UpdateSession()<bar>:qall<cr>
" Loads a session if it exists
nnoremap <silent><leader>ls :call <SID>LoadSession()<cr>
function! s:LoadSession()
if !<SID>DefineSessionPath()
return
endif
" Session file exists
if strlen(findfile(b:sessionFile))
" Session file readable
if filereadable(b:sessionFile)
execute 'source ' . b:sessionFile
redraw!
echo "The session for the directory \"" . getcwd() . "\" has been reloaded."
let g:sessionLoaded = 1
" Session file not readable
else
echohl ErrorMsg
echo "The session \"" . b:sessionFile . "\" isn''t readable.\nPlease check your file permissions (see umask)."
echohl None
endif
" Session file doesn't exist
else
echohl ErrorMsg
echo "There is no session for the directory \"" . getcwd() . "\""
echohl None
endif
endfunction
"if has("autocmd")
" NOTE: Load automatically latest vim session can cause some problems when
" the file doesn't exist anymore (e.g. when edited in /tmp), especially
" after having used 'crontab -e'
" augroup LoadSession
" autocmd VimEnter * nested :call LoadSession()
" augroup end
"endif
" Removes a session
nnoremap <silent><leader>rs :call <SID>RemoveSession()<cr>
function! s:RemoveSession()
if !<SID>DefineSessionPath()
return
endif
if strlen(findfile(b:sessionFile))
" Remove the session file
execute 'silent! !rm -rf ' . b:sessionFile
redraw!
" Remove the directory structure if it is empty
" NOTE: If the directory is not readable or not writable, it won't be removed
execute 'silent !find "' . b:sessionDefaultDir . '" -type d -empty -delete 2>/dev/null'
redraw!
echo "The session \"" . b:sessionFile . "\" has been removed."
endif
endfunction
" FIXME: The following functions will load any files passed as arguments to Vim and
" manage them in different viewports
"if has("autocmd")
" augroup OpenArgsInFiles
" autocmd!
" "autocmd VimEnter * :call <SID>OpenArgsInFiles()
" augroup end
"endif
"function! s:OpenArgsInFiles()
" let l:i = 0
" if argc() > 1
" while l:i < argc()
" execute 'vsplit ' . argv(l:i)
" let l:i += 1
" endwhile
" endif
" echom l:i
"endfunction
"}}}
"{{{ Sourcing mappings
"-------------------------------------------------------------------------------
" Source a local configuration file if available
if filereadable("/etc/vim/vimrc.local")
source /etc/vim/vimrc.local
endif
" Edit directly personal vimrc without losing concentration
" Pay attention, the $MYVIMRC env variable is only set when a vimrc filetype is found.
if strlen($MYVIMRC) != 0
nnoremap <silent><leader>ev :tabnew $MYVIMRC<cr>:echo $MYVIMRC . ' has been loaded in a new tab.'<cr>
nnoremap <silent><leader>sv :silent :source $MYVIMRC<cr>:echo $MYVIMRC . " has been sourced."<cr>
else
nnoremap <silent><leader>ev :echohl ErrorMsg<cr>:echo ".vimrc file not found."<cr>:echohl None<cr>
nnoremap <silent><leader>sv :echohl ErrorMsg<cr>:echo ".vimrc file not found."<cr>:echohl None<cr>
endif
" Source current file
nnoremap <silent><leader>s :source %<cr>:execute 'echo "\"' . expand("%:p") . '\" sourced."'<cr>
"}}}
"{{{ Tabs management
"-------------------------------------------------------------------------------
" Map a key to select directly the numbered tab
map <C-t> :tabnew <cr>
map <S-w> :tabclose <cr>
" Next tab
noremap <S-h> gT
noremap <C-PageUp> gT
" Previous tab
noremap <S-l> gt
noremap <C-PageDown> gt
"}}}
"{{{ Window management
"-------------------------------------------------------------------------------
" Increase window size
nnoremap w+ <C-W>>
" Decrease window size
nnoremap w- <C-W><
"}}}
" vim: set foldmethod=marker foldlevel=0: