From: Jeff King <peff@peff.net>
To: Johannes Sixt <j6t@kdbg.org>
Cc: git@vger.kernel.org, Bart Trojanowski <bart@jukie.net>
Subject: Re: [RFC/PATCH] avoid SIGPIPE warnings for aliases
Date: Fri, 4 Jan 2013 16:25:34 -0500 [thread overview]
Message-ID: <20130104212534.GA2304@sigill.intra.peff.net> (raw)
In-Reply-To: <50E70976.5040001@kdbg.org>
On Fri, Jan 04, 2013 at 05:55:18PM +0100, Johannes Sixt wrote:
> Am 04.01.2013 13:47, schrieb Jeff King:
> > I have two reservations with this patch:
> >
> > 1. We are ignoring SIGPIPE all the time. For an alias that is calling
> > "log", that is fine. But if pack-objects dies on the server side,
> > seeing that it died from SIGPIPE is useful data, and we are
> > squelching that. Maybe callers of run-command should have to pass
> > an "ignore SIGPIPE" flag?
>
> I am of two minds. On the one hand, losing useful debugging information
> is not something we should do lightly. On the other hand, the message is
> really noise most of the time, even on servers: when pack-objects dies
> on the server side, it is most likely due to a connection that breaks
> (voluntarily or involuntarily) half-way during a transfer, and is
> presumably a frequent event, and as such not worth noting most of the time.
Yeah. I'd mostly be worried about a case where pack-objects prints
nothing (because it dies due to pipe), and then the outer process is not
sufficiently verbose (it just says something like "pack-objects died
abnormally", and the user is left scratching their head. I.e., it _is_
uninteresting, but because we are too silent, the user does not even
know it is uninteresting.
Pack-objects is already careful to check all of its writes. I really
think it would be fine to just ignore SIGPIPE, and then it would produce
a useful error message on EPIPE. The downside is that if we accidentally
have an unchecked call, we won't notice the error (we'll probably notice
it later, but we might continue uselessly spewing data in the meantime).
Perhaps we should catch SIGPIPE in such programs and print an error
message.
> > 2. The die_errno in handle_alias is definitely wrong. Even if we want
> > to print a message for signal death, showing errno is bogus unless
> > the return value was -1. But is it the right thing to just pass the
> > negative value straight to exit()? It works, but it is depending on
> > the fact that (unsigned char)(ret & 0xff) behaves in a certain way
> > (i.e., that we are on a twos-complement platform, and -13 becomes
> > 141). That is not strictly portable, but it is probably fine in
> > practice. I'd worry more about exit() doing something weird on
> > Windows.
>
> It did something weird on Windows until we added this line to
> compat/mingw.h:
>
> #define exit(code) exit((code) & 0xff)
Ah, makes sense. I think that hunk of my patch is probably good, then.
-Peff
next prev parent reply other threads:[~2013-01-04 21:25 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-01-04 12:47 [RFC/PATCH] avoid SIGPIPE warnings for aliases Jeff King
2013-01-04 16:55 ` Johannes Sixt
2013-01-04 21:25 ` Jeff King [this message]
2013-01-04 22:20 ` Junio C Hamano
2013-01-05 14:03 ` Jeff King
2013-01-05 14:49 ` [PATCH] run-command: encode signal death as a positive integer Jeff King
2013-01-05 19:50 ` Johannes Sixt
2013-01-05 22:19 ` Jonathan Nieder
2013-01-05 23:12 ` Jeff King
2013-01-05 23:58 ` Jonathan Nieder
2013-01-06 7:05 ` Junio C Hamano
2013-01-09 20:48 ` [RFC/PATCH] avoid SIGPIPE warnings for aliases Junio C Hamano
2013-01-09 20:51 ` Jeff King
2013-01-09 21:49 ` Junio C Hamano
2013-01-10 0:18 ` Jonathan Nieder
2013-01-10 0:39 ` Junio C Hamano
2013-01-10 11:26 ` Jeff King
2013-01-10 20:22 ` Junio C Hamano
2013-01-10 21:39 ` Jeff King
2013-01-10 21:52 ` Johannes Sixt
2013-01-10 22:51 ` Junio C Hamano
2013-01-10 10:49 ` Jeff King
2014-07-21 6:45 ` mimimimi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20130104212534.GA2304@sigill.intra.peff.net \
--to=peff@peff.net \
--cc=bart@jukie.net \
--cc=git@vger.kernel.org \
--cc=j6t@kdbg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).