From: Michael Haggerty <mhagger@xxxxxxxxxxxx> Signed-off-by: Michael Haggerty <mhagger@xxxxxxxxxxxx> --- refs.c | 33 +++++++++++++++++---------------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/refs.c b/refs.c index 4448b14..722545f 100644 --- a/refs.c +++ b/refs.c @@ -440,23 +440,24 @@ static int do_one_ref(const char *base, each_ref_fn fn, int trim, } /* - * Call fn for each reference in dir that has index in the range + * Call fn for each reference in direntry that has index in the range * offset <= index < dir->nr. Recurse into subdirectories that are in * that index range, sorting them before iterating. This function - * does not sort dir itself; it should be sorted beforehand. + * does not sort direntry itself; it should be sorted beforehand. */ -static int do_for_each_ref_in_dir(struct ref_dir *dir, int offset, +static int do_for_each_ref_in_dir(struct ref_entry *direntry, int offset, const char *base, each_ref_fn fn, int trim, int flags, void *cb_data) { int i; - assert(dir->sorted == dir->nr); - for (i = offset; i < dir->nr; i++) { - struct ref_entry *entry = dir->entries[i]; + assert(direntry->flag & REF_DIR); + assert(direntry->u.subdir.sorted == direntry->u.subdir.nr); + for (i = offset; i < direntry->u.subdir.nr; i++) { + struct ref_entry *entry = direntry->u.subdir.entries[i]; int retval; if (entry->flag & REF_DIR) { sort_ref_dir(&entry->u.subdir); - retval = do_for_each_ref_in_dir(&entry->u.subdir, 0, + retval = do_for_each_ref_in_dir(entry, 0, base, fn, trim, flags, cb_data); } else { retval = do_one_ref(base, fn, trim, flags, cb_data, entry); @@ -491,11 +492,11 @@ static int do_for_each_ref_in_dirs(struct ref_entry *direntry1, struct ref_entry *e1, *e2; int cmp; if (i1 == direntry1->u.subdir.nr) { - return do_for_each_ref_in_dir(&direntry2->u.subdir, i2, + return do_for_each_ref_in_dir(direntry2, i2, base, fn, trim, flags, cb_data); } if (i2 == direntry2->u.subdir.nr) { - return do_for_each_ref_in_dir(&direntry1->u.subdir, i1, + return do_for_each_ref_in_dir(direntry1, i1, base, fn, trim, flags, cb_data); } e1 = direntry1->u.subdir.entries[i1]; @@ -532,7 +533,7 @@ static int do_for_each_ref_in_dirs(struct ref_entry *direntry1, if (e->flag & REF_DIR) { sort_ref_dir(&e->u.subdir); retval = do_for_each_ref_in_dir( - &e->u.subdir, 0, + e, 0, base, fn, trim, flags, cb_data); } else { retval = do_one_ref(base, fn, trim, flags, cb_data, e); @@ -542,10 +543,10 @@ static int do_for_each_ref_in_dirs(struct ref_entry *direntry1, return retval; } if (i1 < direntry1->u.subdir.nr) - return do_for_each_ref_in_dir(&direntry1->u.subdir, i1, + return do_for_each_ref_in_dir(direntry1, i1, base, fn, trim, flags, cb_data); if (i2 < direntry2->u.subdir.nr) - return do_for_each_ref_in_dir(&direntry2->u.subdir, i2, + return do_for_each_ref_in_dir(direntry2, i2, base, fn, trim, flags, cb_data); return 0; } @@ -602,7 +603,7 @@ static int is_refname_available(const char *refname, const char *oldrefname, assert(direntry->flag & REF_DIR); sort_ref_dir(&direntry->u.subdir); - if (do_for_each_ref_in_dir(&direntry->u.subdir, 0, "", name_conflict_fn, + if (do_for_each_ref_in_dir(direntry, 0, "", name_conflict_fn, 0, DO_FOR_EACH_INCLUDE_BROKEN, &data)) { error("'%s' exists; cannot create '%s'", @@ -1194,12 +1195,12 @@ static int do_for_each_ref(const char *submodule, const char *base, each_ref_fn } else if (packed_direntry) { sort_ref_dir(&packed_direntry->u.subdir); retval = do_for_each_ref_in_dir( - &packed_direntry->u.subdir, 0, + packed_direntry, 0, base, fn, trim, flags, cb_data); } else if (loose_direntry) { sort_ref_dir(&loose_direntry->u.subdir); retval = do_for_each_ref_in_dir( - &loose_direntry->u.subdir, 0, + loose_direntry, 0, base, fn, trim, flags, cb_data); } @@ -1648,7 +1649,7 @@ static int repack_without_ref(const char *refname) unable_to_lock_error(git_path("packed-refs"), errno); return error("cannot delete '%s' from packed refs", refname); } - do_for_each_ref_in_dir(&packed->u.subdir, 0, + do_for_each_ref_in_dir(packed, 0, "", repack_without_ref_fn, 0, 0, &data); return commit_lock_file(&packlock); } -- 1.7.10 -- 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