Signed-off-by: Michael Haggerty <mhagger@xxxxxxxxxxxx> --- refs.c | 28 +++++++++++++++++++++------- 1 files changed, 21 insertions(+), 7 deletions(-) diff --git a/refs.c b/refs.c index e043555..102ed03 100644 --- a/refs.c +++ b/refs.c @@ -157,7 +157,7 @@ static struct cached_refs { char did_packed; struct ref_list *loose; struct ref_list *packed; -} cached_refs, submodule_refs; +} *cached_refs, *submodule_refs; static struct ref_list *current_ref; static struct ref_list *extra_refs; @@ -181,6 +181,15 @@ static void clear_cached_refs(struct cached_refs *ca) ca->did_loose = ca->did_packed = 0; } +struct cached_refs *create_cached_refs() +{ + struct cached_refs *refs; + refs = xmalloc(sizeof(struct cached_refs)); + refs->did_loose = refs->did_packed = 0; + refs->loose = refs->packed = NULL; + return refs; +} + /* * Return a pointer to a cached_refs for the specified submodule. For * the main repository, use submodule==NULL. The returned structure @@ -189,12 +198,17 @@ static void clear_cached_refs(struct cached_refs *ca) */ static struct cached_refs *get_cached_refs(const char *submodule) { - if (! submodule) - return &cached_refs; - else { - /* For now, don't reuse the refs cache for submodules. */ - clear_cached_refs(&submodule_refs); - return &submodule_refs; + if (! submodule) { + if (!cached_refs) + cached_refs = create_cached_refs(); + return cached_refs; + } else { + if (!submodule_refs) + submodule_refs = create_cached_refs(); + else + /* For now, don't reuse the refs cache for submodules. */ + clear_cached_refs(submodule_refs); + return submodule_refs; } } -- 1.7.6.8.gd2879 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html