X-Git-Url: http://git.iain.cx/?p=profile.git;a=blobdiff_plain;f=.vim%2Fscript%2Fp4;h=4badc84029925984011311b87ccf4034218cd2cf;hp=797033031638968e74d04f23490b2fc8149fecd5;hb=0897bbd45d9649a23a819291f7ab769c563648d1;hpb=d6eec91ae814fc64a5ad5859f0559e95cb2124ca diff --git a/.vim/script/p4 b/.vim/script/p4 index 7970330..4badc84 100644 --- a/.vim/script/p4 +++ b/.vim/script/p4 @@ -4,35 +4,72 @@ fun! P4submit() " There's no point doing this if the spec is readonly. That probably means " it's a submitted change. if ! &ro + setf perforce + " Clear the unnamed register. let @" = "" try " Delete the spec blurb if it exists. - /^# A Perforce Change Spec/,/^$/d + /^# A Perforce Change Spec/,/^# *(New changelists only\.)$/d " If the blurb was deleted the text will be in the unnamed register. if @" != "" + " Delete the blank line left above the remaining fields. + 1 + delete + " Allow closing an unmodified spec. set nomod - " Create a new window, move it below the spec and read in a diff. - botright new - r!p4 diff + try + /everything below this line is just the diff/ + + " We are submitting through git p4 so yank the diff. + normal j + normal yG + " Create a new window below the spec and paste the diff. + botright new + normal p + catch + " Get the files in the changelist. + let l:files = system("sed -n 's@^ \\(//.*\\) #.*@\"\\1\"@p' " . bufname("")) + " Create a new window below the spec and read in a diff. + botright new + if l:files != "" + exe "r!env P4DIFF= p4 diff -du " . substitute(l:files, "\n", " ", "g") + endif + endtry + setf diff " Delete the blank line left above the diff. 1 delete set nobuflisted - set buftype=nofile + set buftype=nowrite set bufhidden=hide setlocal noswapfile + file [p4 diff\] + " Map q to quit easily. + nnoremap q q + + " Vim 7.4 really doesn't want us to quit windows from a script. + try + au QuitPre * qa! + catch + endtry " Switch back to the top window and put the cursor by the description. wincmd k resize 10 - exe "normal G" - ? + normal G + ?^Description: let @/ = "" + normal j + normal ^ + + " Set formatting. + se noexpandtab + se ts=8 endif catch " We get here if no blurb was deleted. This is the case if we aren't @@ -43,7 +80,7 @@ endfun " Expand the command line window so we don't have to press RETURN later. let s:cmdheight = &cmdheight -set cmdheight=2 +set cmdheight=3 " Call and then discard our function. call P4submit() @@ -55,4 +92,10 @@ set noexpandtab exe "set 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