Merge branch 'jk/prune-mtime'
In v2.2.0, we broke "git prune" that runs in a repository that borrows from an alternate object store. * jk/prune-mtime: sha1_file: fix iterating loose alternate objects for_each_loose_file_in_objdir: take an optional strbuf path
This commit is contained in:
44
sha1_file.c
44
sha1_file.c
@ -3359,31 +3359,42 @@ static int for_each_file_in_obj_subdir(int subdir_nr,
|
||||
return r;
|
||||
}
|
||||
|
||||
int for_each_loose_file_in_objdir(const char *path,
|
||||
int for_each_loose_file_in_objdir_buf(struct strbuf *path,
|
||||
each_loose_object_fn obj_cb,
|
||||
each_loose_cruft_fn cruft_cb,
|
||||
each_loose_subdir_fn subdir_cb,
|
||||
void *data)
|
||||
{
|
||||
struct strbuf buf = STRBUF_INIT;
|
||||
size_t baselen;
|
||||
size_t baselen = path->len;
|
||||
int r = 0;
|
||||
int i;
|
||||
|
||||
strbuf_addstr(&buf, path);
|
||||
strbuf_addch(&buf, '/');
|
||||
baselen = buf.len;
|
||||
|
||||
for (i = 0; i < 256; i++) {
|
||||
strbuf_addf(&buf, "%02x", i);
|
||||
r = for_each_file_in_obj_subdir(i, &buf, obj_cb, cruft_cb,
|
||||
strbuf_addf(path, "/%02x", i);
|
||||
r = for_each_file_in_obj_subdir(i, path, obj_cb, cruft_cb,
|
||||
subdir_cb, data);
|
||||
strbuf_setlen(&buf, baselen);
|
||||
strbuf_setlen(path, baselen);
|
||||
if (r)
|
||||
break;
|
||||
}
|
||||
|
||||
return r;
|
||||
}
|
||||
|
||||
int for_each_loose_file_in_objdir(const char *path,
|
||||
each_loose_object_fn obj_cb,
|
||||
each_loose_cruft_fn cruft_cb,
|
||||
each_loose_subdir_fn subdir_cb,
|
||||
void *data)
|
||||
{
|
||||
struct strbuf buf = STRBUF_INIT;
|
||||
int r;
|
||||
|
||||
strbuf_addstr(&buf, path);
|
||||
r = for_each_loose_file_in_objdir_buf(&buf, obj_cb, cruft_cb,
|
||||
subdir_cb, data);
|
||||
strbuf_release(&buf);
|
||||
|
||||
return r;
|
||||
}
|
||||
|
||||
@ -3396,9 +3407,16 @@ static int loose_from_alt_odb(struct alternate_object_database *alt,
|
||||
void *vdata)
|
||||
{
|
||||
struct loose_alt_odb_data *data = vdata;
|
||||
return for_each_loose_file_in_objdir(alt->base,
|
||||
data->cb, NULL, NULL,
|
||||
data->data);
|
||||
struct strbuf buf = STRBUF_INIT;
|
||||
int r;
|
||||
|
||||
/* copy base not including trailing '/' */
|
||||
strbuf_add(&buf, alt->base, alt->name - alt->base - 1);
|
||||
r = for_each_loose_file_in_objdir_buf(&buf,
|
||||
data->cb, NULL, NULL,
|
||||
data->data);
|
||||
strbuf_release(&buf);
|
||||
return r;
|
||||
}
|
||||
|
||||
int for_each_loose_object(each_loose_object_fn cb, void *data)
|
||||
|
||||
Reference in New Issue
Block a user