]> git.ipfire.org Git - thirdparty/git.git/blobdiff - reachable.c
refs: make verify_refname_available() virtual
[thirdparty/git.git] / reachable.c
index 59196253a60c03a622276279788e642fe36f076b..ed352018964ef2260f5da51239800bbcc816ad1b 100644 (file)
@@ -25,9 +25,15 @@ static void update_progress(struct connectivity_progress *cp)
 static int add_one_ref(const char *path, const struct object_id *oid,
                       int flag, void *cb_data)
 {
-       struct object *object = parse_object_or_die(oid->hash, path);
        struct rev_info *revs = (struct rev_info *)cb_data;
+       struct object *object;
 
+       if ((flag & REF_ISSYMREF) && (flag & REF_ISBROKEN)) {
+               warning("symbolic ref is dangling: %s", path);
+               return 0;
+       }
+
+       object = parse_object_or_die(oid->hash, path);
        add_pending_object(revs, object, "");
 
        return 0;