Skip to content

Commit 81b9b5a

Browse files
mhaggergitster
authored andcommitted
mmapped_ref_iterator_advance(): no peeled value for broken refs
If a reference is broken, suppress its peeled value. Signed-off-by: Michael Haggerty <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 9cfb3dc commit 81b9b5a

File tree

1 file changed

+8
-2
lines changed

1 file changed

+8
-2
lines changed

refs/packed-backend.c

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -234,9 +234,15 @@ static int mmapped_ref_iterator_advance(struct ref_iterator *ref_iterator)
234234

235235
/*
236236
* Regardless of what the file header said, we
237-
* definitely know the value of *this* reference:
237+
* definitely know the value of *this* reference. But
238+
* we suppress it if the reference is broken:
238239
*/
239-
iter->base.flags |= REF_KNOWS_PEELED;
240+
if ((iter->base.flags & REF_ISBROKEN)) {
241+
oidclr(&iter->peeled);
242+
iter->base.flags &= ~REF_KNOWS_PEELED;
243+
} else {
244+
iter->base.flags |= REF_KNOWS_PEELED;
245+
}
240246
} else {
241247
oidclr(&iter->peeled);
242248
}

0 commit comments

Comments
 (0)