Это то, что беспокоило меня долгое время. Вероятно, «правильным» решением было бы представить патч для самого vim, который позволил бы вам настраивать границы абзацев с помощью регулярного выражения (например: устанавливать абзацы, но на самом деле полезно).
Тем временем я создал функцию и пару сопоставлений, которые почти делают правильные вещи:
function! ParagraphMove(delta, visual)
normal m'
normal |
if a:visual
normal gv
endif
if a:delta > 0
" first whitespace-only line following a non-whitespace character
let pos1 = search("\\S", "W")
let pos2 = search("^\\s*$", "W")
if pos1 == 0 || pos2 == 0
let pos = search("\\%$", "W")
endif
elseif a:delta < 0
" first whitespace-only line preceding a non-whitespace character
let pos1 = search("\\S", "bW")
let pos2 = search("^\\s*$", "bW")
if pos1 == 0 || pos2 == 0
let pos = search("\\%^", "bW")
endif
endif
normal |
endfunction
nnoremap <silent> } :call ParagraphMove( 1, 0)<CR>
onoremap <silent> } :call ParagraphMove( 1, 0)<CR>
" vnoremap <silent> } :call ParagraphMove( 1, 1)<CR>
nnoremap <silent> { :call ParagraphMove(-1, 0)<CR>
onoremap <silent> { :call ParagraphMove(-1, 0)<CR>
" vnoremap <silent> { :call ParagraphMove(-1, 1)<CR>
Это неправильно обрабатывает счет, например, '4} или в визуальном режиме (раскомментируйте строки vnoremap на свой страх и риск), но, похоже, подходит для таких вещей, как не загромождение текущего шаблона поиска и не мерцание. Кроме того, 'd}', 'y}' и т. Д., Кажется, работают нормально. Если у кого-то есть идеи, как сделать подсчет или исправить визуальный режим, пожалуйста, дайте мне знать.