Avoid scary errors about tagged trees/blobs during git-fetch
authorLinus Torvalds <torvalds@linux-foundation.org>
Thu, 18 Oct 2007 23:24:47 +0000 (16:24 -0700)
committerShawn O. Pearce <spearce@spearce.org>
Fri, 19 Oct 2007 00:37:52 +0000 (20:37 -0400)
Ok, what is going on is:

 - append_fetch_head() looks up the SHA1 for all heads (including tags):

        if (get_sha1(head, sha1))
                return error("Not a valid object name: %s", head);

 - it then wants to check if it's a candidate for merging (because
   fetching also does the whole "list which heads to merge" in case
   it is going to be part of a "pull"):

        commit = lookup_commit_reference(sha1);
        if (!commit)
                not_for_merge = 1;

 - and that "lookup_commit_reference()" is just very vocal about the
   case where it fails. It really shouldn't be, and it shouldn't
   affect the actual end result, but that basically explains why
   you get that scary warning.

In short, the warning is just bogus, and should be harmless, but
I agree that it's ugly. I think the appended patch should fix it.

Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
builtin-fetch--tool.c

index e2f8ede9ae4507ed1e431f9d14fc649f6475627d..db133348a8f7f52a7f246aeb7f61a6cacbd8e3cb 100644 (file)
@@ -148,7 +148,7 @@ static int append_fetch_head(FILE *fp,
 
        if (get_sha1(head, sha1))
                return error("Not a valid object name: %s", head);
-       commit = lookup_commit_reference(sha1);
+       commit = lookup_commit_reference_gently(sha1, 1);
        if (!commit)
                not_for_merge = 1;