Make sure we barf on ref^{type} failure.
authorJunio C Hamano <junkio@cox.net>
Thu, 20 Oct 2005 05:48:16 +0000 (22:48 -0700)
committerJunio C Hamano <junkio@cox.net>
Thu, 20 Oct 2005 05:49:31 +0000 (22:49 -0700)
Martin Langhoff noticed that ref^0 barfed correctly when we did not
have the commit in a broken repository, but ref^{commit} didn't.

Signed-off-by: Junio C Hamano <junkio@cox.net>
sha1_name.c

index 75c688e..cc320d3 100644 (file)
@@ -323,6 +323,8 @@ static int peel_onion(const char *name, int len, unsigned char *sha1)
                return -1;
        if (!type_string) {
                o = deref_tag(o);
+               if (!o || (!o->parsed && !parse_object(o->sha1)))
+                       return -1;
                memcpy(sha1, o->sha1, 20);
        }
        else {
@@ -332,7 +334,7 @@ static int peel_onion(const char *name, int len, unsigned char *sha1)
                 */
 
                while (1) {
-                       if (!o)
+                       if (!o || (!o->parsed && !parse_object(o->sha1)))
                                return -1;
                        if (o->type == type_string) {
                                memcpy(sha1, o->sha1, 20);