From: Michael Haggerty <mhagger@xxxxxxxxxxxx> Packed references are stored in $GIT_DIR/packed-refs sorted, so adjacent ones are pretty likely to be in the same directory. So while reading them, keep track of the last directory used, and reuse it if possible to avoid searching the reference namespace from the root each time. Signed-off-by: Michael Haggerty <mhagger@xxxxxxxxxxxx> --- refs.c | 16 +++++++++++++++- 1 files changed, 15 insertions(+), 1 deletions(-) diff --git a/refs.c b/refs.c index 312ca3b..92523fd 100644 --- a/refs.c +++ b/refs.c @@ -780,6 +780,7 @@ static const char *parse_ref_line(char *line, unsigned char *sha1) static void read_packed_refs(FILE *f, struct ref_entry *direntry) { struct ref_entry *last = NULL; + struct ref_entry *current_direntry = NULL; char refline[PATH_MAX]; int flag = REF_ISPACKED; @@ -799,8 +800,21 @@ static void read_packed_refs(FILE *f, struct ref_entry *direntry) refname = parse_ref_line(refline, sha1); if (refname) { + if (current_direntry) { + char *slash = strrchr(refname, '/'); + if (!slash + || strncmp(current_direntry->name, refname, + slash - refname + 1) + || current_direntry->name[slash - refname + 1] != '\0') + /* The new refname does not go in current_direntry */ + current_direntry = NULL; + } + if (!current_direntry) + current_direntry = find_containing_direntry( + direntry, refname, 1); + last = create_ref_entry(refname, sha1, flag, 1); - add_ref(direntry, last); + add_entry(current_direntry, last); continue; } if (last && -- 1.7.8 -- 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