Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.kernel.org/pub/scm/git/git.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2011-03-24 00:55:49 +0300
committerJunio C Hamano <gitster@pobox.com>2011-03-24 00:55:49 +0300
commiteec3bd44d835a98e06808d472fd428b31aef3114 (patch)
tree8177229b60251b23feee9ec1c2d68de7d392b67c
parent3ed8868474b6309304696a15a1bec184ea235750 (diff)
parentebec842773932e6f853acac70c80f84209b5f83e (diff)
Merge branch 'jn/fortify-source-workaround'
* jn/fortify-source-workaround: run-command: prettify -D_FORTIFY_SOURCE workaround
-rw-r--r--run-command.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/run-command.c b/run-command.c
index f91e446c86..8619c769a9 100644
--- a/run-command.c
+++ b/run-command.c
@@ -67,21 +67,26 @@ static int child_notifier = -1;
static void notify_parent(void)
{
- ssize_t unused;
- unused = write(child_notifier, "", 1);
+ /*
+ * execvp failed. If possible, we'd like to let start_command
+ * know, so failures like ENOENT can be handled right away; but
+ * otherwise, finish_command will still report the error.
+ */
+ if (write(child_notifier, "", 1))
+ ; /* yes, dear gcc -D_FORTIFY_SOURCE, there was an error. */
}
static NORETURN void die_child(const char *err, va_list params)
{
char msg[4096];
- ssize_t unused;
int len = vsnprintf(msg, sizeof(msg), err, params);
if (len > sizeof(msg))
len = sizeof(msg);
- unused = write(child_err, "fatal: ", 7);
- unused = write(child_err, msg, len);
- unused = write(child_err, "\n", 1);
+ if (write(child_err, "fatal: ", 7) ||
+ write(child_err, msg, len) ||
+ write(child_err, "\n", 1))
+ ; /* yes, gcc -D_FORTIFY_SOURCE, we know there was an error. */
exit(128);
}
#endif