Mercurial > dotfiles.old
annotate vimrc @ 23:4112c6eb9f47
Correct tab completion with snippets
author | zegervdv <zegervdv@me.com> |
---|---|
date | Thu, 20 Mar 2014 21:49:38 +0100 |
parents | b2c16cd71d95 |
children | c3bb025ed67e |
rev | line source |
---|---|
0 | 1 set nocompatible |
2 set laststatus=2 | |
3 set noshowmode | |
4 | |
5 execute pathogen#infect() | |
6 | |
7 set backspace=2 | |
8 set autowrite | |
9 | |
10 set vb | |
11 set guioptions-=r | |
12 set guioptions-=l | |
13 set guioptions-=R | |
14 set guioptions-=L | |
15 | |
16 syntax on | |
17 set expandtab | |
18 set number | |
19 set ruler | |
20 set nocursorline | |
21 set showmatch | |
22 set title | |
23 set wrap | |
24 set wrapmargin=2 | |
25 set linebreak | |
26 set lbr | |
27 set tabstop=2 shiftwidth=2 | |
21
bf5c5093bad9
Add Base16-Ocean-Dark colorscheme
zegervdv <zegervdv@me.com>
parents:
19
diff
changeset
|
28 if has("gui_running") |
bf5c5093bad9
Add Base16-Ocean-Dark colorscheme
zegervdv <zegervdv@me.com>
parents:
19
diff
changeset
|
29 set background=dark |
22 | 30 color hybrid |
21
bf5c5093bad9
Add Base16-Ocean-Dark colorscheme
zegervdv <zegervdv@me.com>
parents:
19
diff
changeset
|
31 else |
bf5c5093bad9
Add Base16-Ocean-Dark colorscheme
zegervdv <zegervdv@me.com>
parents:
19
diff
changeset
|
32 color hybrid |
bf5c5093bad9
Add Base16-Ocean-Dark colorscheme
zegervdv <zegervdv@me.com>
parents:
19
diff
changeset
|
33 endif |
0 | 34 set guifont=Inconsolata\ for\ Powerline:h12 |
35 set autowrite | |
36 set hidden | |
37 set hlsearch | |
38 set incsearch | |
39 set ignorecase | |
40 set smartcase | |
41 set smartindent | |
42 set autoindent | |
43 set scrolloff=4 | |
44 set textwidth=80 | |
45 | |
46 set history=100 | |
47 set wildmenu | |
19 | 48 set wildmode=full |
0 | 49 |
50 set diffopt+=iwhite | |
51 | |
52 set formatoptions= | |
53 set formatoptions+=c " Format comments | |
54 set formatoptions+=r " Continue comments by default | |
55 set formatoptions+=o " Make comment when using o or O from comment line | |
56 set formatoptions+=q " Format comments with gq | |
57 set formatoptions+=n " Recognize numbered lists | |
58 set formatoptions+=2 " Use indent from 2nd line of a paragraph | |
59 set formatoptions+=l " Don't break lines that are already long | |
60 set formatoptions+=1 " Break before 1-letter words | |
61 | |
62 set splitright | |
63 set virtualedit=block | |
64 set conceallevel=0 | |
65 | |
66 set cryptmethod=blowfish | |
67 | |
68 filetype plugin indent on | |
69 autocmd FileType ruby set tabstop=2|set shiftwidth=2 | |
70 | |
71 set clipboard=unnamed | |
72 | |
16 | 73 set viminfo='10,\"100,:20,%,n~/.viminfo |
74 | |
75 " When editing a file, always jump to the last known cursor position. | |
76 " Don't do it for commit messages, when the position is invalid, or when | |
77 " inside an event handler (happens when dropping a file on gvim). | |
78 autocmd BufReadPost * | |
79 \ if &ft != 'gitcommit' && line("'\"") > 0 && line("'\"") <= line("$") | | |
80 \ exe "normal g`\"" | | |
81 \ endif | |
0 | 82 |
83 map <Leader>d :bp<bar>sp<bar>bn<bar>bd<CR> | |
84 | |
85 " See long lines as line breaks | |
86 map j gj | |
87 map k gk | |
88 | |
89 " remap tag-search to better place | |
90 nmap <C-$> <C-]> | |
91 | |
92 " Jump to end of line in insert mode | |
93 inoremap <C-e> <C-o>A | |
94 | |
95 " Jump one character in insert mode | |
96 inoremap <C-f> <C-o>l | |
97 | |
4
050d4d8c6796
Vim: use double space to alternate files
zegervdv <zegervdv@me.com>
parents:
3
diff
changeset
|
98 " Switch between the last two files |
050d4d8c6796
Vim: use double space to alternate files
zegervdv <zegervdv@me.com>
parents:
3
diff
changeset
|
99 nnoremap <SPACE><SPACE> <C-^> |
050d4d8c6796
Vim: use double space to alternate files
zegervdv <zegervdv@me.com>
parents:
3
diff
changeset
|
100 |
0 | 101 " Very Magic search patterns |
102 nmap / /\v | |
103 cmap s/ s/\v | |
104 | |
105 | |
106 inoremap £ \ | |
107 | |
4
050d4d8c6796
Vim: use double space to alternate files
zegervdv <zegervdv@me.com>
parents:
3
diff
changeset
|
108 " nnoremap <SPACE> <C-e> |
0 | 109 |
110 " Close Quickfix window (,qq) | |
5 | 111 " map <leader>qq :cclose<CR> |
0 | 112 |
113 nnoremap <silent> n n:call HLNext(0.4)<cr> | |
114 nnoremap <silent> N N:call HLNext(0.4)<cr> | |
115 | |
116 function! HLNext (blinktime) | |
117 highlight WhiteOnRed ctermfg=white ctermbg=red guifg=white guibg=red | |
118 let [bufnum, lnum, col, off] = getpos('.') | |
119 let matchlen = strlen(matchstr(strpart(getline('.'),col-1),@/)) | |
120 let target_pat = '\c\%#'.@/ | |
121 let ring = matchadd('WhiteOnRed', target_pat, 101) | |
122 redraw | |
123 exec 'sleep ' . float2nr(a:blinktime * 1000) . 'm' | |
124 call matchdelete(ring) | |
125 redraw | |
126 endfunction | |
127 | |
128 " Swap v and CTRL-V | |
129 nnoremap v <C-V> | |
130 nnoremap <C-V> v | |
131 | |
132 vnoremap v <C-V> | |
133 vnoremap <C-V> v | |
134 | |
135 " Use backspace as delete in visual mode | |
136 vmap <BS> x | |
137 | |
138 " Keep selection when shifting | |
139 vmap <expr> > KeepVisualSelection(">") | |
140 vmap <expr> < KeepVisualSelection("<") | |
141 | |
142 function! KeepVisualSelection(cmd) | |
143 set nosmartindent | |
144 if mode() ==# "V" | |
145 return a:cmd . ":set smartindent\<CR>gv" | |
146 else | |
147 return a:cmd . ":set smartindent\<CR>" | |
148 endif | |
149 endfunction | |
150 | |
151 let g:indent_guides_auto_colors = 0 | |
152 let g:indent_guides_guide_size = 1 | |
153 highlight IndentGuidesEven guibg=background | |
154 highlight IndentGuidesOdd guibg='#282a2e' | |
155 | |
156 " Show trailing whitespaces | |
157 " exec "set listchars=tab:\uBB\uBB,trail:\uB7,nbsp:~" | |
158 " set list | |
159 | |
160 " Vim Math plugin; make simple calculations | |
161 vmap <expr> ++ VMATH_YankAndAnalyse() | |
162 nmap ++ vip++ | |
163 | |
164 " Airline configuration | |
165 let g:airline_inactive_collapse=0 | |
166 let g:airline_powerline_fonts=1 | |
167 | |
168 let g:airline_left_sep = '' | |
169 let g:airline_right_sep = '' | |
170 | |
171 let g:airline_theme = 'tomorrow' | |
172 | |
173 let g:airline#extensions#syntastic#enabled = 0 | |
174 | |
175 nnoremap <F5> :buffers<CR>:buffer<Space> | |
176 noremap <C-TAB> <C-w><C-w> | |
177 | |
178 " Set leader to , | |
179 let mapleader = "," | |
180 | |
181 " Custom key mappings | |
182 | |
183 let g:yankring_replace_n_pkey = 'cp' | |
184 | |
185 " Nerdtree | |
186 map <F2> :NERDTreeToggle<CR> | |
187 map <Leader>e :NERDTreeToggle<CR> | |
188 let NERDTreeIgnore = ['\.aux$', '\.log$', '\.out$'] | |
189 | |
190 " Vim - Rspec | |
191 map <leader>t :call RunCurrentSpecFile()<CR> | |
192 map <leader>s :call RunNearestSpec()<CR> | |
193 map <leader>l :call RunLastSpec()<CR> | |
194 map <leader>r :call RunAllSpecs()<CR> | |
195 | |
196 " Cucumber | |
197 map <leader>f :call RunAllFeatures()<CR> | |
198 map <leader>k :call RunCurrentFeature()<CR> | |
199 | |
200 " Autocomplete | |
201 inoremap <C-Space> <C-N> | |
202 | |
203 " Single char insertion | |
204 " nmap <Space> i_<Esc>r | |
205 | |
206 " Clear highlight | |
207 nnoremap <silent> <leader>n :nohlsearch<CR> | |
208 | |
209 " ctrl p - Fuzzy file finder | |
210 noremap <C-p> :CtrlP<CR> | |
211 let g:ctrl_map = '<c-p>' | |
212 let g:ctrl_cmd = 'CtrlP' | |
213 | |
214 map <C-l> :CtrlPBuffer<CR> | |
215 map <C-m> :CtrlPTag<CR> | |
216 | |
5 | 217 if executable('ag') |
218 let g:ctrlp_user_command = 'ag %s -l --nocolor -g ""' | |
219 let g:ctrlp_use_caching = 0 | |
220 endif | |
221 | |
0 | 222 " ctrl p - Commands |
223 map <leader>p :CtrlPCmdPalette<CR> | |
224 | |
225 " Markdown | |
226 let g:vim_markdown_folding_disabled=1 | |
227 | |
228 " tComment remap | |
229 nmap <leader>c <C-_><C-_> | |
230 | |
231 " Neo Complete | |
232 let g:acp_enableAtStartup=0 | |
233 let g:neocomplete#enable_at_startup=1 | |
234 let g:neocomplete#enable_smart_case=1 | |
235 let g:neocomplete#sources#syntax#min_keyword_length=3 | |
236 let g:neocomplete#lock_buffer_name_pattern = '\*ku\*' | |
237 | |
238 " Define dictionary. | |
239 let g:neocomplete#sources#dictionary#dictionaries = { | |
240 \ 'default' : '', | |
241 \ 'vimshell' : $HOME.'/.vimshell_hist', | |
242 \ 'scheme' : $HOME.'/.gosh_completions' | |
243 \ } | |
244 " Recommended key-mappings. | |
245 " <CR>: close popup and save indent. | |
246 inoremap <silent> <CR> <C-r>=<SID>my_cr_function()<CR> | |
247 function! s:my_cr_function() | |
248 return neocomplete#close_popup() . "\<CR>" | |
249 " For no inserting <CR> key. | |
250 "return pumvisible() ? neocomplete#close_popup() : "\<CR>" | |
251 endfunction | |
252 " <TAB>: completion. | |
253 inoremap <expr><TAB> pumvisible() ? "\<C-n>" : "\<TAB>" | |
254 " <C-h>, <BS>: close popup and delete backword char. | |
255 inoremap <expr><C-h> neocomplete#smart_close_popup()."\<C-h>" | |
256 | |
257 autocmd FileType css setlocal omnifunc=csscomplete#CompleteCSS | |
258 autocmd FileType html,markdown setlocal omnifunc=htmlcomplete#CompleteTags | |
259 autocmd FileType javascript setlocal omnifunc=javascriptcomplete#CompleteJS | |
260 autocmd FileType python setlocal omnifunc=pythoncomplete#Complete | |
261 autocmd FileType xml setlocal omnifunc=xmlcomplete#CompleteTags | |
262 autocmd FileType ruby setlocal omnifunc=rubycomplete#Complete | |
263 if !exists('g:neocomplete#sources#omni#input_patterns') | |
264 let g:neocomplete#sources#omni#input_patterns = {} | |
265 endif | |
266 | |
267 " Neo Snippets | |
268 imap <C-k> <Plug>(neosnippet_expand_or_jump) | |
269 smap <C-k> <Plug>(neosnippet_expand_or_jump) | |
270 xmap <C-k> <Plug>(neosnippet_expand_target) | |
271 | |
23
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
272 " imap <expr><TAB> neosnippet#expandable_or_jumpable() ? |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
273 " \ "\<Plug>(neosnippet_expand_or_jump)" |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
274 " \: pumvisible() ? "\<C-n>" : "\<TAB>" |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
275 " smap <expr><TAB> neosnippet#expandable_or_jumpable() ? |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
276 " \ "\<Plug>(neosnippet_expand_or_jump)" |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
277 " \: "\<TAB>" |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
278 |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
279 |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
280 imap <expr><TAB> neosnippet#expandable() == 1 ? "\<Plug>(neosnippet_expand_or_jump)" : pumvisible() ? "\<C-n>" : "\<TAB>" |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
281 imap <expr><C-k> neosnippet#expandable_or_jumpable() == 1 ? "\<Plug>(neosnippet_expand_or_jump)" : pumvisible() ? "\<C-n>" : "\<TAB>" |
4112c6eb9f47
Correct tab completion with snippets
zegervdv <zegervdv@me.com>
parents:
22
diff
changeset
|
282 smap <expr><TAB> neosnippet#expandable() == 1 ? "\<Plug>(neosnippet_expand_or_jump)" : pumvisible() ? "\<C-n>" : "\<TAB>" |
0 | 283 let g:neocomplete#sources#omni#input_patterns.ruby = '[^. *\t]\.\w*\|\h\w*::' |
284 | |
285 let g:neosnippet#snippets_directory='~/.vim/snippets' | |
286 | |
287 " Tabular | |
288 inoremap <silent> <Bar> <Bar><Esc>:call <SID>align()<CR>a | |
289 | |
290 function! s:align() | |
291 let p = '^\s*|\s.*\s|\s*$' | |
292 if exists(':Tabularize') && getline('.') =~# '^\s*|' && (getline(line('.')-1) =~# p || getline(line('.')+1) =~# p) | |
293 let column = strlen(substitute(getline('.')[0:col('.')],'[^|]','','g')) | |
294 let position = strlen(matchstr(getline('.')[0:col('.')],'.*|\s*\zs.*')) | |
295 Tabularize/|/l1 | |
296 normal! 0 | |
297 call search(repeat('[^|]*|',column).'\s\{-\}'.repeat('.',position),'ce',line('.')) | |
298 endif | |
299 endfunction | |
300 | |
301 " Align Migration files | |
302 vmap <c-a> :Tabularize /:/l1l0l0<CR> | |
303 | |
304 nmap <Leader>a= :Tabularize /=<CR> | |
305 vmap <Leader>a= :Tabularize /=<CR> | |
306 nmap <Leader>a=> :Tabularize /=><CR> | |
307 vmap <Leader>a=> :Tabularize /=><CR> | |
308 nmap <Leader>a: :Tabularize /:\zs/l0l1<CR> | |
309 vmap <Leader>a: :Tabularize /:\zs/l0l1<CR> | |
310 nmap <Leader>a, :Tabularize /,\zs/l0l1<CR> | |
311 vmap <Leader>a, :Tabularize /,\zs/l0l1<CR> | |
312 vmap <Leader>a- :Tabularize /-<CR> | |
313 | |
314 | |
315 | |
316 augroup markdown | |
317 au! | |
318 au BufNewFile,BufRead *.md,*.markdown setlocal filetype=ghmarkdown | |
319 augroup END | |
320 | |
321 | |
322 " Latex plugin | |
323 au BufNewFile,BufRead,BufEnter *.tex setlocal spell spelllang=en_gb | |
324 au BufNewFile,BufRead,BufEnter *.tex setlocal textwidth=0 | |
325 au BufNewFile,BufRead,BufEnter *.txt setlocal spell spelllang=en_gb | |
326 au BufNewFile,BufRead,BufEnter *.txt setlocal textwidth=0 | |
327 | |
328 let g:tex_conseal = "" | |
329 | |
330 let g:tex_comment_nospell=1 | |
331 let g:Tex_DefaultTargetFormat = 'pdf' | |
332 let g:tex_flavor = 'latex' | |
333 let g:Tex_TreatMacViewerAsUNIX = 1 | |
334 let g:Tex_ExecuterUNIXViewerInForeground = 1 | |
335 let g:Tex_ViewRule_pdf = 'open -a Preview' | |
336 let g:Tex_ViewRule_ps = 'open -a Preview' | |
337 | |
338 " Tagbar mapping | |
339 nmap <F8> :TagbarToggle<CR> | |
340 | |
341 " The silver searcher | |
342 " let g:ackprg = 'ag --nogroup --nocolor --column' | |
343 | |
344 " Multiple cursor insert | |
345 let g:multi_cursor_next_key='<C-n>' | |
346 let g:multi_cursor_prev_key='<C-m>' | |
347 let g:multi_cursor_skip_key='<C-x>' | |
348 let g:multi_cursor_quit_key='<Esc>' | |
349 | |
350 " Gundo tree | |
351 nnoremap <leader>u :GundoToggle<CR> | |
352 | |
353 " Yank ring | |
354 nnoremap <silent> <leader>y :YRShow<CR> | |
355 | |
13 | 356 " Open pdf in Preview |
0 | 357 let g:livepreview_previewer = 'open -a Preview' |
3
44d3af8838f8
Add support for local zshrc and vimrc files
zegervdv <zegervdv@me.com>
parents:
0
diff
changeset
|
358 |
13 | 359 |
360 " Smalls | |
361 nmap s <Plug>(smalls) | |
362 omap s <Plug>(smalls) | |
363 xmap s <Plug>(smalls) | |
364 | |
14
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
365 " Textmanip |
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
366 xmap <C-j> <Plug>(textmanip-move-down) |
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
367 xmap <C-k> <Plug>(textmanip-move-up) |
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
368 xmap <C-h> <Plug>(textmanip-move-left) |
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
369 xmap <C-l> <Plug>(textmanip-move-right) |
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
370 xmap <F10> <Plug>(textmanip-toggle-mode) |
09c60bc0fc38
Add vim-textmanip for visual block dragging
zegervdv <zegervdv@me.com>
parents:
13
diff
changeset
|
371 |
13 | 372 " Load local vimrc |
3
44d3af8838f8
Add support for local zshrc and vimrc files
zegervdv <zegervdv@me.com>
parents:
0
diff
changeset
|
373 if filereadable($HOME . "/.vimrc.local") |
44d3af8838f8
Add support for local zshrc and vimrc files
zegervdv <zegervdv@me.com>
parents:
0
diff
changeset
|
374 source ~/.vimrc.local |
44d3af8838f8
Add support for local zshrc and vimrc files
zegervdv <zegervdv@me.com>
parents:
0
diff
changeset
|
375 endif |