" Delete the spec blurb if it exists.
/^# A Perforce Change Spec/,/^# *(New changelists only\.)$/d
" If the blurb was deleted the text will be in the unnamed register.
- if @" != "grgergregergeg"
+ if @" != ""
" Delete the blank line left above the remaining fields.
1
delete
" Allow closing an unmodified spec.
set nomod
- " Get the files in the changelist.
- let l:files = system("sed -n 's@^ \\(//.*\\) #.*@\\1@p' " . bufname(""))
- " Create a new window, move it 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
+ 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
set buftype=nowrite
set bufhidden=hide
setlocal noswapfile
- file [p4 diff]
+ file [p4 diff\]
" Switch back to the top window and put the cursor by the description.
wincmd k
resize 10
- exe "normal G"
- ?<enter description here>
+ 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