Merge branch 'mh/ref-api-lazy-loose'
The code to lazily read loose refs unnecessarily read the refs in a subhierarchy by mistake when we free the data for the subhierarchy. By Michael Haggerty * mh/ref-api-lazy-loose: free_ref_entry(): do not trigger reading of loose refs
This commit is contained in:
commit
38f2b874ff
9
refs.c
9
refs.c
@ -259,8 +259,13 @@ static void clear_ref_dir(struct ref_dir *dir);
|
|||||||
|
|
||||||
static void free_ref_entry(struct ref_entry *entry)
|
static void free_ref_entry(struct ref_entry *entry)
|
||||||
{
|
{
|
||||||
if (entry->flag & REF_DIR)
|
if (entry->flag & REF_DIR) {
|
||||||
clear_ref_dir(get_ref_dir(entry));
|
/*
|
||||||
|
* Do not use get_ref_dir() here, as that might
|
||||||
|
* trigger the reading of loose refs.
|
||||||
|
*/
|
||||||
|
clear_ref_dir(&entry->u.subdir);
|
||||||
|
}
|
||||||
free(entry);
|
free(entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user