From: Roman Kagan Date: Mon, 2 Apr 2012 13:52:34 +0000 (+0400) Subject: git-svn: ignore SIGPIPE X-Git-Tag: v1.7.11-rc0~113 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=6ade9bdadaf61565ee4e2ab47f66baaf41a20ecf;p=git.git git-svn: ignore SIGPIPE In HTTP with keep-alive it's not uncommon for the client to notice that the server decided to stop maintaining the current connection only when sending a new request. This naturally results in -EPIPE and possibly SIGPIPE. The subversion library itself makes no provision for SIGPIPE. Some combinations of the underlying libraries do (typically SIG_IGN-ing it), some don't. Presumably for that reason all subversion commands set SIGPIPE to SIG_IGN early in their main()-s. So should we. This, together with the previous patch, fixes the notorious "git-svn died of signal 13" problem (see e.g. http://thread.gmane.org/gmane.comp.version-control.git/134936). Signed-off-by: Roman Kagan Acked-by: Eric Wong --- diff --git a/git-svn.perl b/git-svn.perl index 570504cee..aa14564e3 100755 --- a/git-svn.perl +++ b/git-svn.perl @@ -36,6 +36,11 @@ $ENV{TZ} = 'UTC'; $| = 1; # unbuffer STDOUT sub fatal (@) { print STDERR "@_\n"; exit 1 } + +# All SVN commands do it. Otherwise we may die on SIGPIPE when the remote +# repository decides to close the connection which we expect to be kept alive. +$SIG{PIPE} = 'IGNORE'; + sub _req_svn { require SVN::Core; # use()-ing this causes segfaults for me... *shrug* require SVN::Ra;