diff options
Diffstat (limited to 'vim/init/keymaps.vim')
-rw-r--r-- | vim/init/keymaps.vim | 181 |
1 files changed, 62 insertions, 119 deletions
diff --git a/vim/init/keymaps.vim b/vim/init/keymaps.vim index 3360a53..f7098a6 100644 --- a/vim/init/keymaps.vim +++ b/vim/init/keymaps.vim | |||
@@ -2,28 +2,13 @@ | |||
2 | " | 2 | " |
3 | " Only for key mapping | 3 | " Only for key mapping |
4 | " | 4 | " |
5 | " COMMON_MAPPING | ||
6 | " MANAGE_VIMRC | ||
7 | " MOVING_WITH_READLINE | ||
8 | " INSERT_SURROUNDING | ||
9 | " JUMP_TO_TABS_WITH_ALT | ||
10 | " MANAGE_TABS | ||
11 | " MANAGE_BUFFERS | ||
12 | " MANAGE_WINDOWS | ||
13 | " FOLDING | ||
14 | " SURROURD_WITH_CHAR | ||
15 | " REDIRECTION_WITH_BUFFER | ||
16 | " QUICK_SUBSTITUTE | ||
17 | " GIT_TIG | ||
18 | " 终端支持 | 5 | " 终端支持 |
19 | " 编译运行 | 6 | " 编译运行 |
20 | " | 7 | " |
21 | "====================================================================== | 8 | "====================================================================== |
22 | " vim: set ts=4 sw=4 tw=78 noet : | 9 | " vim: set ts=4 sw=4 tw=78 noet : |
23 | 10 | ||
24 | "---------------------------------------------------------------------- | 11 | " COMMON_MAPPING ----------------{{{ |
25 | " COMMON_MAPPING | ||
26 | "---------------------------------------------------------------------- | ||
27 | 12 | ||
28 | " Space for searching | 13 | " Space for searching |
29 | map <space> / | 14 | map <space> / |
@@ -135,18 +120,13 @@ nnoremap <leader>so V:so<CR> | |||
135 | nnoremap <leader><leader>so :source ~/.vimrc<CR> | 120 | nnoremap <leader><leader>so :source ~/.vimrc<CR> |
136 | vnoremap so :source<CR> | 121 | vnoremap so :source<CR> |
137 | 122 | ||
138 | 123 | " }}} | |
139 | "---------------------------------------------------------------------- | 124 | " MANAGE_VIMRC ----------------{{{ |
140 | " MANAGE_VIMRC | ||
141 | "---------------------------------------------------------------------- | ||
142 | nnoremap <leader>e :scriptnames<space> | 125 | nnoremap <leader>e :scriptnames<space> |
143 | nnoremap <leader>ee :edit $MYVIMRC<CR> | 126 | nnoremap <leader>ee :edit $MYVIMRC<CR> |
144 | autocmd! BUFWRITEPOST $MYVIMRC source $MYVIMRC | 127 | autocmd! BUFWRITEPOST $MYVIMRC source $MYVIMRC |
145 | 128 | " }}} | |
146 | 129 | " MOVING_WITH_READLINE ----------------{{{ | |
147 | "---------------------------------------------------------------------- | ||
148 | " MOVING_WITH_READLINE | ||
149 | "---------------------------------------------------------------------- | ||
150 | inoremap <C-f> <Right> | 130 | inoremap <C-f> <Right> |
151 | inoremap <C-b> <Left> | 131 | inoremap <C-b> <Left> |
152 | inoremap <C-a> <C-o>0 | 132 | inoremap <C-a> <C-o>0 |
@@ -178,19 +158,15 @@ noremap <m-j> gj | |||
178 | noremap <m-k> gk | 158 | noremap <m-k> gk |
179 | inoremap <m-j> <c-\><c-o>gj | 159 | inoremap <m-j> <c-\><c-o>gj |
180 | inoremap <m-k> <c-\><c-o>gk | 160 | inoremap <m-k> <c-\><c-o>gk |
181 | 161 | " }}} | |
182 | "---------------------------------------------------------------------- | 162 | " INSERT_SURROUNDING ----------------{{{ |
183 | " INSERT_SURROUNDING | ||
184 | "---------------------------------------------------------------------- | ||
185 | inoremap ' ''<Left> | 163 | inoremap ' ''<Left> |
186 | inoremap " ""<Left> | 164 | inoremap " ""<Left> |
187 | inoremap ( ()<Left> | 165 | inoremap ( ()<Left> |
188 | inoremap [ []<Left> | 166 | inoremap [ []<Left> |
189 | inoremap { {}<Left> | 167 | inoremap { {}<Left> |
190 | 168 | " }}} | |
191 | "---------------------------------------------------------------------- | 169 | " JUMP_TO_TABS_WITH_ALT ----------------{{{ |
192 | " JUMP_TO_TABS_WITH_ALT | ||
193 | "---------------------------------------------------------------------- | ||
194 | noremap <silent><A-1> :tabn 1<CR> | 170 | noremap <silent><A-1> :tabn 1<CR> |
195 | noremap <silent><A-2> :tabn 2<CR> | 171 | noremap <silent><A-2> :tabn 2<CR> |
196 | noremap <silent><M-3> :tabn 3<CR> | 172 | noremap <silent><M-3> :tabn 3<CR> |
@@ -209,11 +185,8 @@ inoremap <silent><M-6> <Esc>:tabn 6<CR> | |||
209 | inoremap <silent><M-7> <Esc>:tabn 7<CR> | 185 | inoremap <silent><M-7> <Esc>:tabn 7<CR> |
210 | inoremap <silent><M-8> <Esc>:tabn 8<CR> | 186 | inoremap <silent><M-8> <Esc>:tabn 8<CR> |
211 | inoremap <silent><M-9> <Esc>:tablast<CR> | 187 | inoremap <silent><M-9> <Esc>:tablast<CR> |
212 | 188 | " }}} | |
213 | 189 | " MANAGE_TABS ----------------{{{ | |
214 | "---------------------------------------------------------------------- | ||
215 | " MANAGE_TABS | ||
216 | "---------------------------------------------------------------------- | ||
217 | 190 | ||
218 | " Useful mappings for managing tabs | 191 | " Useful mappings for managing tabs |
219 | map <leader>tn :tabnew<CR> | 192 | map <leader>tn :tabnew<CR> |
@@ -246,11 +219,8 @@ function! Tab_MoveRight() | |||
246 | exec 'tabmove '.l:tabnr | 219 | exec 'tabmove '.l:tabnr |
247 | endif | 220 | endif |
248 | endfunc | 221 | endfunc |
249 | 222 | " }}} | |
250 | 223 | " MANAGE_BUFFERS ----------------{{{ | |
251 | "---------------------------------------------------------------------- | ||
252 | " MANAGE_BUFFERS | ||
253 | "---------------------------------------------------------------------- | ||
254 | 224 | ||
255 | " Open a new buffer | 225 | " Open a new buffer |
256 | nmap <leader><leader>b :enew<CR> | 226 | nmap <leader><leader>b :enew<CR> |
@@ -294,18 +264,43 @@ function! s:SwitchDiffForGitHEAD() | |||
294 | endfunction | 264 | endfunction |
295 | com! SwitchDiffForGitHEAD call s:SwitchDiffForGitHEAD() | 265 | com! SwitchDiffForGitHEAD call s:SwitchDiffForGitHEAD() |
296 | nnoremap <C-w>D <Cmd>silent! SwitchDiffForGitHEAD<CR> | 266 | nnoremap <C-w>D <Cmd>silent! SwitchDiffForGitHEAD<CR> |
297 | 267 | " }}} | |
298 | 268 | " MANAGE_WINDOWS ----------------{{{ | |
299 | "---------------------------------------------------------------------- | ||
300 | " MANAGE_WINDOWS | ||
301 | "---------------------------------------------------------------------- | ||
302 | nnoremap <leader><leader>sb :windo set scrollbind!<CR> | 269 | nnoremap <leader><leader>sb :windo set scrollbind!<CR> |
303 | 270 | ||
304 | 271 | " 窗口切换:ALT+SHIFT+hjkl | |
305 | "---------------------------------------------------------------------- | 272 | " 传统的 CTRL+hjkl 移动窗口不适用于 vim 8.1 的终端模式,CTRL+hjkl 在 |
306 | " FOLDING | 273 | " bash/zsh 及带文本界面的程序中都是重要键位需要保留,不能 tnoremap 的 |
307 | "---------------------------------------------------------------------- | 274 | "---------------------------------------------------------------------- |
275 | noremap <m-H> <c-w>h | ||
276 | noremap <m-L> <c-w>l | ||
277 | noremap <m-J> <c-w>j | ||
278 | noremap <m-K> <c-w>k | ||
279 | inoremap <m-H> <esc><c-w>h | ||
280 | inoremap <m-L> <esc><c-w>l | ||
281 | inoremap <m-J> <esc><c-w>j | ||
282 | inoremap <m-K> <esc><c-w>k | ||
308 | 283 | ||
284 | if has('terminal') && exists(':terminal') == 2 && has('patch-8.1.1') | ||
285 | " vim 8.1 支持 termwinkey ,不需要把 terminal 切换成 normal 模式 | ||
286 | " 设置 termwinkey 为 CTRL 加减号(GVIM),有些终端下是 CTRL+? | ||
287 | " 后面四个键位是搭配 termwinkey 的,如果 termwinkey 更改,也要改 | ||
288 | set termwinkey=<c-_> | ||
289 | tnoremap <m-H> <c-_>h | ||
290 | tnoremap <m-L> <c-_>l | ||
291 | tnoremap <m-J> <c-_>j | ||
292 | tnoremap <m-K> <c-_>k | ||
293 | tnoremap <m-q> <c-\><c-n> | ||
294 | elseif has('nvim') | ||
295 | " neovim 没有 termwinkey 支持,必须把 terminal 切换回 normal 模式 | ||
296 | tnoremap <m-H> <c-\><c-n><c-w>h | ||
297 | tnoremap <m-L> <c-\><c-n><c-w>l | ||
298 | tnoremap <m-J> <c-\><c-n><c-w>j | ||
299 | tnoremap <m-K> <c-\><c-n><c-w>k | ||
300 | tnoremap <m-q> <c-\><c-n> | ||
301 | endif | ||
302 | " }}} | ||
303 | " FOLDING ----------------{{{ | ||
309 | " Set foldmethod | 304 | " Set foldmethod |
310 | noremap <leader><leader>fm :<C-\>e'set foldmethod='..&foldmethod<CR> | 305 | noremap <leader><leader>fm :<C-\>e'set foldmethod='..&foldmethod<CR> |
311 | 306 | ||
@@ -317,11 +312,8 @@ nnoremap <expr> l foldclosed('.') == -1 ? 'l' : 'zo' | |||
317 | " Open fold in next line | 312 | " Open fold in next line |
318 | nnoremap <expr> zo foldclosed('.') == -1 ? 'zjzo' : 'zo' | 313 | nnoremap <expr> zo foldclosed('.') == -1 ? 'zjzo' : 'zo' |
319 | nnoremap <expr> zO foldclosed('.') == -1 ? 'zjzO' : 'zO' | 314 | nnoremap <expr> zO foldclosed('.') == -1 ? 'zjzO' : 'zO' |
320 | 315 | " }}} | |
321 | 316 | " SURROURD_WITH_CHAR ----------------{{{ | |
322 | "---------------------------------------------------------------------- | ||
323 | " SURROURD_WITH_CHAR | ||
324 | "---------------------------------------------------------------------- | ||
325 | vnoremap S sa | 317 | vnoremap S sa |
326 | vnoremap ' <ESC>`<i'<ESC>`>la'<ESC> | 318 | vnoremap ' <ESC>`<i'<ESC>`>la'<ESC> |
327 | vnoremap q <ESC>`<i"<ESC>`>la"<ESC> | 319 | vnoremap q <ESC>`<i"<ESC>`>la"<ESC> |
@@ -331,11 +323,9 @@ vnoremap { <ESC>`<i{<ESC>`>la}<ESC> | |||
331 | vnoremap ` <ESC>`<i`<ESC>`>la`<ESC> | 323 | vnoremap ` <ESC>`<i`<ESC>`>la`<ESC> |
332 | vnoremap <space> <ESC>`<i<space><ESC>`>la<space><ESC> | 324 | vnoremap <space> <ESC>`<i<space><ESC>`>la<space><ESC> |
333 | vnoremap Q <ESC>`<i「<ESC>`>la」<ESC> | 325 | vnoremap Q <ESC>`<i「<ESC>`>la」<ESC> |
326 | " }}} | ||
327 | " REDIRECTION_WITH_BUFFER ----------------{{{ | ||
334 | 328 | ||
335 | |||
336 | "---------------------------------------------------------------------- | ||
337 | " REDIRECTION_WITH_BUFFER | ||
338 | "---------------------------------------------------------------------- | ||
339 | " Usage: | 329 | " Usage: |
340 | " :Redir hi ............. show the full output of command ':hi' in a scratch window | 330 | " :Redir hi ............. show the full output of command ':hi' in a scratch window |
341 | " :Redir !ls -al ........ show the full output of command ':!ls -al' in a scratch window | 331 | " :Redir !ls -al ........ show the full output of command ':!ls -al' in a scratch window |
@@ -362,12 +352,10 @@ endfunction | |||
362 | 352 | ||
363 | command! -nargs=1 -complete=command Redir silent call Redir(<q-args>) | 353 | command! -nargs=1 -complete=command Redir silent call Redir(<q-args>) |
364 | nnoremap <leader>rr :Redir<space> | 354 | nnoremap <leader>rr :Redir<space> |
355 | " }}} | ||
356 | " QUICK_SUBSTITUTE ----------------{{{ | ||
365 | 357 | ||
366 | 358 | " Usage: Press <TAB> n times for area, and <CR> for substitute | |
367 | "---------------------------------------------------------------------- | ||
368 | " QUICK_SUBSTITUTE | ||
369 | " Press <TAB> n times for area, and <CR> for substitute | ||
370 | "---------------------------------------------------------------------- | ||
371 | 359 | ||
372 | " substitute across file | 360 | " substitute across file |
373 | vnoremap <leader>s y:%s//<C-R>0/g<LEFT><LEFT> | 361 | vnoremap <leader>s y:%s//<C-R>0/g<LEFT><LEFT> |
@@ -395,21 +383,16 @@ vnoremap <TAB> <Cmd>call ExpandSelectionBySearch('/')<CR> | |||
395 | vnoremap <S-TAB> <Cmd>call ExpandSelectionBySearch('?')<CR> | 383 | vnoremap <S-TAB> <Cmd>call ExpandSelectionBySearch('?')<CR> |
396 | vnoremap <CR> <Cmd>call SubstituteBySearch()<CR> | 384 | vnoremap <CR> <Cmd>call SubstituteBySearch()<CR> |
397 | 385 | ||
398 | 386 | " }}} | |
399 | "---------------------------------------------------------------------- | 387 | " GIT_TIG ----------------{{{ |
400 | " GIT_TIG | ||
401 | "---------------------------------------------------------------------- | ||
402 | let g:tig_explorer_keymap_commit_split = '<C-s>' | 388 | let g:tig_explorer_keymap_commit_split = '<C-s>' |
403 | let g:tig_explorer_keymap_commit_vsplit = '<C-v>' | 389 | let g:tig_explorer_keymap_commit_vsplit = '<C-v>' |
404 | nnoremap <C-t> <Cmd>Tig<CR> | 390 | nnoremap <C-t> <Cmd>Tig<CR> |
405 | nnoremap <C-t>s <Cmd>TigStatus<CR> | 391 | nnoremap <C-t>s <Cmd>TigStatus<CR> |
406 | nnoremap <C-t>b <Cmd>TigBlame<CR> | 392 | nnoremap <C-t>b <Cmd>TigBlame<CR> |
407 | nnoremap <C-t>d :vertical TigOpenFileWithCommit <C-R>+ % 0<CR> | 393 | nnoremap <C-t>d :vertical TigOpenFileWithCommit <C-R>+ % 0<CR> |
408 | 394 | " }}} | |
409 | 395 | " Markdown items (temproray solution) ----------------{{{ | |
410 | "---------------------------------------------------------------------- | ||
411 | " Markdown items (temproray solution) | ||
412 | "---------------------------------------------------------------------- | ||
413 | 396 | ||
414 | " Toggle list item in markdown: "- [ ] XXX" -> "XXX" -> "- XXX" -> "- [ ] XXX" | 397 | " Toggle list item in markdown: "- [ ] XXX" -> "XXX" -> "- XXX" -> "- [ ] XXX" |
415 | " autocmd FileType markdown nnoremap <buffer> <leader>i V:!sed -E '/^ *- \[.\]/ { s/^( *)- \[.\] */\1/; q; }; /^ *[^[:space:]-]/ { s/^( *)/\1- /; q; }; /^ *- / { s/^( *)- /\1- [ ] /; q; }'<CR><CR> | 398 | " autocmd FileType markdown nnoremap <buffer> <leader>i V:!sed -E '/^ *- \[.\]/ { s/^( *)- \[.\] */\1/; q; }; /^ *[^[:space:]-]/ { s/^( *)/\1- /; q; }; /^ *- / { s/^( *)- /\1- [ ] /; q; }'<CR><CR> |
@@ -417,53 +400,14 @@ nnoremap <C-t>d :vertical TigOpenFileWithCommit <C-R>+ % 0<CR> | |||
417 | 400 | ||
418 | " Toggle task status: "- [ ] " -> "- [x]" -> "- [.] " -> "- [ ] " | 401 | " Toggle task status: "- [ ] " -> "- [x]" -> "- [.] " -> "- [ ] " |
419 | " nnoremap <leader>x V:!sed -E '/^ *- \[ \]/ { s/^( *)- \[ \]/\1- [x]/; q; }; /^ *- \[\x\]/ { s/^( *)- \[\x\]/\1- [.]/; q; }; /^ *- \[\.\]/ { s/^( *)- \[\.\]/\1- [ ]/; q; }'<CR><CR> | 402 | " nnoremap <leader>x V:!sed -E '/^ *- \[ \]/ { s/^( *)- \[ \]/\1- [x]/; q; }; /^ *- \[\x\]/ { s/^( *)- \[\x\]/\1- [.]/; q; }; /^ *- \[\.\]/ { s/^( *)- \[\.\]/\1- [ ]/; q; }'<CR><CR> |
420 | 403 | " }}} | |
421 | 404 | " Common system command ----------------{{{ | |
422 | "---------------------------------------------------------------------- | ||
423 | " Common command | ||
424 | "---------------------------------------------------------------------- | ||
425 | " Show date selector | 405 | " Show date selector |
426 | nnoremap <leader>dd :r !sh -c 'LANG=en zenity --calendar --date-format="\%Y.\%m.\%d" 2>/dev/null'<CR><CR> | 406 | nnoremap <leader>dd :r !sh -c 'LANG=en zenity --calendar --date-format="\%Y.\%m.\%d" 2>/dev/null'<CR><CR> |
427 | nnoremap <leader>dD :r !sh -c 'LANG=en zenity --calendar --date-format="\%a \%b \%d" 2>/dev/null'<CR><CR> | 407 | nnoremap <leader>dD :r !sh -c 'LANG=en zenity --calendar --date-format="\%a \%b \%d" 2>/dev/null'<CR><CR> |
428 | nnoremap <leader>dt :r !date +\%H:\%m<CR>A | 408 | nnoremap <leader>dt :r !date +\%H:\%m<CR>A |
429 | 409 | " }}} | |
430 | 410 | " Compile ----------------{{{ | |
431 | "---------------------------------------------------------------------- | ||
432 | " 窗口切换:ALT+SHIFT+hjkl | ||
433 | " 传统的 CTRL+hjkl 移动窗口不适用于 vim 8.1 的终端模式,CTRL+hjkl 在 | ||
434 | " bash/zsh 及带文本界面的程序中都是重要键位需要保留,不能 tnoremap 的 | ||
435 | "---------------------------------------------------------------------- | ||
436 | noremap <m-H> <c-w>h | ||
437 | noremap <m-L> <c-w>l | ||
438 | noremap <m-J> <c-w>j | ||
439 | noremap <m-K> <c-w>k | ||
440 | inoremap <m-H> <esc><c-w>h | ||
441 | inoremap <m-L> <esc><c-w>l | ||
442 | inoremap <m-J> <esc><c-w>j | ||
443 | inoremap <m-K> <esc><c-w>k | ||
444 | |||
445 | if has('terminal') && exists(':terminal') == 2 && has('patch-8.1.1') | ||
446 | " vim 8.1 支持 termwinkey ,不需要把 terminal 切换成 normal 模式 | ||
447 | " 设置 termwinkey 为 CTRL 加减号(GVIM),有些终端下是 CTRL+? | ||
448 | " 后面四个键位是搭配 termwinkey 的,如果 termwinkey 更改,也要改 | ||
449 | set termwinkey=<c-_> | ||
450 | tnoremap <m-H> <c-_>h | ||
451 | tnoremap <m-L> <c-_>l | ||
452 | tnoremap <m-J> <c-_>j | ||
453 | tnoremap <m-K> <c-_>k | ||
454 | tnoremap <m-q> <c-\><c-n> | ||
455 | elseif has('nvim') | ||
456 | " neovim 没有 termwinkey 支持,必须把 terminal 切换回 normal 模式 | ||
457 | tnoremap <m-H> <c-\><c-n><c-w>h | ||
458 | tnoremap <m-L> <c-\><c-n><c-w>l | ||
459 | tnoremap <m-J> <c-\><c-n><c-w>j | ||
460 | tnoremap <m-K> <c-\><c-n><c-w>k | ||
461 | tnoremap <m-q> <c-\><c-n> | ||
462 | endif | ||
463 | |||
464 | |||
465 | |||
466 | "---------------------------------------------------------------------- | ||
467 | " 编译运行 C/C++ 项目 | 411 | " 编译运行 C/C++ 项目 |
468 | " 详细见:http://www.skywind.me/blog/archives/2084 | 412 | " 详细见:http://www.skywind.me/blog/archives/2084 |
469 | "---------------------------------------------------------------------- | 413 | "---------------------------------------------------------------------- |
@@ -501,7 +445,6 @@ if has('win32') || has('win64') | |||
501 | endif | 445 | endif |
502 | 446 | ||
503 | 447 | ||
504 | "---------------------------------------------------------------------- | ||
505 | " F5 运行当前文件:根据文件类型判断方法,并且输出到 quickfix 窗口 | 448 | " F5 运行当前文件:根据文件类型判断方法,并且输出到 quickfix 窗口 |
506 | "---------------------------------------------------------------------- | 449 | "---------------------------------------------------------------------- |
507 | function! ExecuteFile() | 450 | function! ExecuteFile() |
@@ -548,7 +491,6 @@ endfunc | |||
548 | 491 | ||
549 | 492 | ||
550 | 493 | ||
551 | "---------------------------------------------------------------------- | ||
552 | " F2 在项目目录下 Grep 光标下单词,默认 C/C++/Py/Js ,扩展名自己扩充 | 494 | " F2 在项目目录下 Grep 光标下单词,默认 C/C++/Py/Js ,扩展名自己扩充 |
553 | " 支持 rg/grep/findstr ,其他类型可以自己扩充 | 495 | " 支持 rg/grep/findstr ,其他类型可以自己扩充 |
554 | " 不是在当前目录 grep,而是会去到当前文件所属的项目目录 project root | 496 | " 不是在当前目录 grep,而是会去到当前文件所属的项目目录 project root |
@@ -569,3 +511,4 @@ else | |||
569 | \ --include='*.js' --include='*.vim' | 511 | \ --include='*.js' --include='*.vim' |
570 | \ '<root>' <CR> | 512 | \ '<root>' <CR> |
571 | endif | 513 | endif |
514 | " }}} | ||