" 在编辑的时候,我经常需要暂时离开当前的位置作一些操作后再返回原处.虽然m和'命令 " 但是一个寄存器只能保存一项内容,假如我需要保存多项当前位置就必须要用多个寄存
" 器并记住其保存顺序,才能正确返回.我只想把自己的注重力放在要编辑的内容上,而不 " 是去费力地记住这些东西.我希望寄存器能像堆栈一样工作,安照后进先出的顺序处理 " 保存的多项位置. " 我用一个字符串来模拟堆栈的行为,各项之间用符号#分开.入栈时,将内容追加到字符串 " 的右边;出栈时,取出从右边开始的第一个#开始的子串. 2004-12-21 17:48:24 " 在编辑的时候,我经常需要暂时离开当前的位置作一些操作后再返回原处.虽然m和'命令 " 但是一个寄存器只能保存一项内容,假如我需要保存多项当前位置就必须要用多个寄存 " 器并记住其保存顺序,才能正确返回.我只想把自己的注重力放在要编辑的内容上,而不 " 是去费力地记住这些东西.我希望寄存器能像堆栈一样工作,安照后进先出的顺序处理 " 保存的多项位置. " 我用一个字符串来模拟堆栈的行为,各项之间用符号#分开.入栈时,将内容追加到字符串 " 的右边;出栈时,取出从右边开始的第一个#开始的子串.
function! PushPosition() let l:locate = line(".") . "." . col(".")
if !exists("s:position_heap") let s:position_heap = "#" . l:locate else let s:position_heap = s:position_heap . "#" . l:locate endif
echo "push position:" . l:locate endfunction
function! PopPosition() if !exists("s:position_heap") return endif
let l:last_push = strridx(s:position_heap, "#") if l:last_push == -1 return else let l:position = strpart(s:position_heap, l:last_push + 1) let l:row = strpart(l:position, 0, stridx(l:position, ".")) let l:column = strpart(l:position, stridx(l:position, ".") + 1) call cursor(l:row, l:column)
let s:position_heap = strpart(s:position_heap, 0, l:last_push) endif endfunction
--------------- 这是我自己写的VIM两个函数,放在plugin目录下。 在查看程序代码时很有用。 我将这两个函数调用绑定在F9和CTRL+F9上,当碰到要记录位置时,就F9,F9,...,需要返回原点时就CTRL+F9,CTRL+F9,...
|