From 387cb5c2a017fb4203ad4b29560179239d53d629 Mon Sep 17 00:00:00 2001 From: Tim Pope Date: Sat, 20 Jul 2019 23:35:24 -0400 Subject: [PATCH] Clean up error reporting on :Gwrite in diff --- autoload/fugitive.vim | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/autoload/fugitive.vim b/autoload/fugitive.vim index e73b16a..db80f57 100644 --- a/autoload/fugitive.vim +++ b/autoload/fugitive.vim @@ -3766,13 +3766,15 @@ function! s:WriteCommand(line1, line2, range, count, bang, mods, reg, arg, args) silent write setlocal buftype=nowrite if matchstr(getline(2),'index [[:xdigit:]]\+\.\.\zs[[:xdigit:]]\{7\}') ==# fugitive#RevParse(':0:'.filename)[0:6] - let err = s:TreeChomp('apply', '--cached', '--reverse', '--', expand('%:p')) + let [message, exec_error] = s:ChompError(['apply', '--cached', '--reverse', '--', expand('%:p')]) else - let err = s:TreeChomp('apply', '--cached', '--', expand('%:p')) + let [message, exec_error] = s:ChompError(['apply', '--cached', '--', expand('%:p')]) endif - if err !=# '' - let v:errmsg = split(err,"\n")[0] - return 'echoerr v:errmsg' + if exec_error + echohl ErrorMsg + echo message + echohl NONE + return '' elseif a:bang return 'bdelete' else