X-Git-Url: http://git.iain.cx/?p=profile.git;a=blobdiff_plain;f=.vim%2Fscript%2Fsvn;h=c927fe41828efb3f5725cb304fa2f2bf77ceeb79;hp=fcca7e4ad9c7dd3c0c9358c8c0964b4a4035b547;hb=518d9698777610c32b50ac83d8a9463be91f0563;hpb=dfa89955cebc320a07b0228f743c000a838bf601 diff --git a/.vim/script/svn b/.vim/script/svn index fcca7e4..c927fe4 100644 --- a/.vim/script/svn +++ b/.vim/script/svn @@ -1,22 +1,30 @@ -" $Id$ vim: set syntax=vim: +" $Id$ vim: se syntax=vim: " Define the function we'll use. It's easier to do this than to faff about " trying to run a sequence of normal mode commands. fun! SVNcommit() " Allow closing an unmodified spec. set nomod + " Get the modified files. Discount new files. + let l:files = system("sed -n '1,/^$/d;s/^[MR]....//p' " . bufname("")) + + if l:files == "" + return + endif + " Create a new window, move it below the spec and read in a diff. botright new - r!svn diff + exe "r!svn diff " . substitute(l:files, "\n", " ", "g") setf diff " Delete the blank line left above the diff. 1 delete se nobuflisted - set buftype=nofile + set buftype=nowrite set bufhidden=hide setlocal noswapfile + file [svn diff] " Switch back to the top window. wincmd k @@ -24,7 +32,7 @@ endfun " Expand the command line window so we don't have to press RETURN later. let s:cmdheight = &cmdheight -se cmdheight=2 +se cmdheight=3 " Call and then discard our function. call SVNcommit() @@ -34,10 +42,4 @@ delfunction SVNcommit exe "se cmdheight=" . s:cmdheight " Close the scratch buffer. -if version >= 700 - " Vim 7 lets us close the buffer by number. The changelist is always in #1. - au BufWinLeave qa! -else - " Prior versions can only do it by name. Fall back to a temporary file. - au BufWinLeave /tmp/tmp.*.* qa! -endif +au BufWinLeave qa!