From: Nicolas Pitre <nico@cam.org>
To: git@vger.kernel.org
Subject: Re: 'git fast-export' is crashing on the gcc repo
Date: Tue, 11 Dec 2007 17:06:42 -0500 (EST) [thread overview]
Message-ID: <alpine.LFD.0.99999.0712111703380.555@xanadu.home> (raw)
In-Reply-To: <alpine.LFD.0.99999.0712111509270.555@xanadu.home>
On Tue, 11 Dec 2007, Nicolas Pitre wrote:
> Simply doing something like:
>
> $ git fast-export --all > /dev/null
>
> results in:
>
> fatal: Could not write blob e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
>
> Since this is extremely enlightening, I patched it as follows:
>
> diff --git a/builtin-fast-export.c b/builtin-fast-export.c
> index 2136aad..5c7bfe0 100755
> --- a/builtin-fast-export.c
> +++ b/builtin-fast-export.c
> @@ -104,7 +104,8 @@ static void handle_object(const unsigned char *sha1)
>
> printf("blob\nmark :%d\ndata %lu\n", last_idnum, size);
> if (fwrite(buf, size, 1, stdout) != 1)
> - die ("Could not write blob %s", sha1_to_hex(sha1));
> + die ("Could not write blob %s: %s",
> + sha1_to_hex(sha1), strerror(errno));
> printf("\n");
>
> show_progress();
>
> And then running it again produced:
>
> fatal: Could not write blob e69de29bb2d1d6434b8b29ae775ad8c2e48c5391: Inappropriate ioctl for device
>
> adding to today's confusion.
Well, ignore the above. It seems that most of stdio doesn't set errno
so the above is crap.
Even strace doesn't show any error.
But, somehow, the following patch fixes it:
diff --git a/builtin-fast-export.c b/builtin-fast-export.c
index 2136aad..c32a124 100755
--- a/builtin-fast-export.c
+++ b/builtin-fast-export.c
@@ -103,7 +103,7 @@ static void handle_object(const unsigned char *sha1)
mark_object(object);
printf("blob\nmark :%d\ndata %lu\n", last_idnum, size);
- if (fwrite(buf, size, 1, stdout) != 1)
+ if (fwrite(buf, 1, size, stdout) != size)
die ("Could not write blob %s", sha1_to_hex(sha1));
printf("\n");
Go figure.
Nicolas
next prev parent reply other threads:[~2007-12-11 22:07 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-12-11 20:27 'git fast-export' is crashing on the gcc repo Nicolas Pitre
2007-12-11 20:35 ` Marco Costalba
2007-12-11 22:01 ` [PATCH] Fix git-fast-export for zero-sized blobs Alex Riesen
2007-12-11 22:20 ` Nicolas Pitre
2007-12-11 22:06 ` Nicolas Pitre [this message]
2007-12-12 1:38 ` 'git fast-export' is crashing on the gcc repo Alex Riesen
2007-12-12 1:45 ` Nicolas Pitre
2007-12-12 8:32 ` Junio C Hamano
2007-12-12 8:46 ` David Kastrup
2007-12-12 8:56 ` Junio C Hamano
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=alpine.LFD.0.99999.0712111703380.555@xanadu.home \
--to=nico@cam.org \
--cc=git@vger.kernel.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).