X-Git-Url: http://git.iain.cx/?a=blobdiff_plain;f=.vim%2Fscript%2Fsvn;h=f648862f8f54a8b2e1649ed5c1b64f005b06b4b2;hb=0d1d3e8398fd0d7844edf1e2ad13d1adc245de17;hp=152d2c9793d0a4a6b030b818f94a335f1db7c2d0;hpb=62e3b6db3f63d02dc4e47fe7cc4d56b1f2d4b9ef;p=profile.git diff --git a/.vim/script/svn b/.vim/script/svn index 152d2c9..f648862 100644 --- a/.vim/script/svn +++ b/.vim/script/svn @@ -2,7 +2,7 @@ " trying to run a sequence of normal mode commands. fun! SVNcommit() " Allow closing an unmodified spec. - set nomod + set nomodified " Get the modified files. Discount new files. let l:files = system("sed -n '1,/^$/d;/^[MR]..../{s//\"/;s/$/\"/p;}' " . bufname("")) @@ -19,13 +19,15 @@ fun! SVNcommit() " Delete the blank line left above the diff. 1 delete - se nobuflisted - set buftype=nowrite - set bufhidden=hide + set ro + set nomodifiable + set nomodified + set nobuflisted + set buftype=help setlocal noswapfile file [svn diff\] " Map q to quit easily. - noremap q q + nnoremap q q " Switch back to the top window. wincmd k @@ -43,4 +45,10 @@ delfunction SVNcommit exe "se cmdheight=" . s:cmdheight " Close the scratch buffer. -au BufWinLeave qa! +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