Essa pesquisa move 40 caracteres (mas não bytes) para a frente:
/\_.\{40}/e
pesquisando exatamente 40 caracteres ( \{40}
) de qualquer tipo, incluindo nova linha ( \_.
) e colocando o cursor no final da pesquisa ( /e
). Veja: http://vimregex.com/#Non-Greedy , :help search-offset
e:help \_
Veja também :h 23.4
para edição binária.
Atualização: Com base nesta resposta, aqui está uma função que salta para deslocamento de bytes:
let s:last_jump_bytes = 0
function! JumpTo(byte_nr)
let crt_byte = line2byte(line('.')) + col('.')
if (a:byte_nr == 0)
let dst_byte = crt_byte + s:last_jump_bytes
else
let dst_byte = crt_byte + a:byte_nr
let s:last_jump_bytes = a:byte_nr
endif
let dst_line = byte2line(dst_byte)
let dst_col = dst_byte -line2byte(dst_line)
"remove next line if you don't want to record this for `Ctrl-O`
execute "normal " . dst_line . "G"
call setpos('.', [0, dst_line, dst_col])
endfunction
command! -nargs=1 JumpToOffset :call JumpTo(<f-args>)
" silly mapping to Ctrl-C (demo)
nnoremap <expr> <silent> <c-c> ":<c-u>call JumpTo(" . v:count . ")<cr>"
Pode ser usado assim:
:JumpToOffset 400
ou digitando o mapeamento do teclado mapeado, com uma contagem:
40CTRL-C
Se você não usar uma contagem, o número da contagem anterior será reutilizado. Então você pode fazer: 40CTRL-C CTRL-C CTRL-C 30CTRL-C CTRL-C
pular 40, 40, 40, 30, 30 bytes etc.
Clique Ctrl-O
para voltar (consulte os comentários dentro da função).
Xl
(ondeX
está o número de caracteres) ou o número de caracteres seguido pela seta para a direita.