Merge pull request #19 from bps/workaround-vim-7-3-411

Use a named register for visual mode put.
This commit is contained in:
Tom McDonald 2014-02-04 11:23:10 -08:00
commit b82a774e6f

View File

@ -1,18 +1,20 @@
function! s:exchange(x, y, reverse) function! s:exchange(x, y, reverse)
let a = getpos("'a") let a = getpos("'a")
let b = getpos("'b") let b = getpos("'b")
let reg = getreg('"') let reg_z = getreg('z')
let reg_mode = getregtype('"') let reg_z_mode = getregtype('z')
let reg_unnamed = getreg('"')
let reg_unnamed_mode = getregtype('"')
call setpos("'a", a:y[2]) call setpos("'a", a:y[2])
call setpos("'b", a:y[3]) call setpos("'b", a:y[3])
call setreg('"', a:x[0], a:x[1]) call setreg('z', a:x[0], a:x[1])
silent exe "normal! `a" . a:y[1] . "`b\"\"p" silent exe "normal! `a" . a:y[1] . "`b\"zp"
call setpos("'a", a:x[2]) call setpos("'a", a:x[2])
call setpos("'b", a:x[3]) call setpos("'b", a:x[3])
call setreg('"', a:y[0], a:y[1]) call setreg('z', a:y[0], a:y[1])
silent exe "normal! `a" . a:x[1] . "`b\"\"p" silent exe "normal! `a" . a:x[1] . "`b\"zp"
if a:reverse if a:reverse
call cursor(a:x[2][1], a:x[2][2]) call cursor(a:x[2][1], a:x[2][2])
@ -22,7 +24,8 @@ function! s:exchange(x, y, reverse)
call setpos("'a", a) call setpos("'a", a)
call setpos("'b", b) call setpos("'b", b)
call setreg('"', reg, reg_mode) call setreg('z', reg_z, reg_z_mode)
call setreg('"', reg_unnamed, reg_unnamed_mode)
endfunction endfunction
function! s:exchange_get(type, vis) function! s:exchange_get(type, vis)