Merge branch 'jk/loose-object-cache'
Code clean-up with optimization for the codepath that checks (non-)existence of loose objects. * jk/loose-object-cache: odb_load_loose_cache: fix strbuf leak fetch-pack: drop custom loose object cache sha1-file: use loose object cache for quick existence check object-store: provide helpers for loose_objects_cache sha1-file: use an object_directory for the main object dir handle alternates paths the same as the main object dir sha1_file_name(): overwrite buffer instead of appending rename "alternate_object_database" to "object_directory" submodule--helper: prefer strip_suffix() to ends_with() fsck: do not reuse child_process structs
This commit is contained in:
@ -1265,19 +1265,20 @@ struct submodule_alternate_setup {
|
||||
SUBMODULE_ALTERNATE_ERROR_IGNORE, NULL }
|
||||
|
||||
static int add_possible_reference_from_superproject(
|
||||
struct alternate_object_database *alt, void *sas_cb)
|
||||
struct object_directory *odb, void *sas_cb)
|
||||
{
|
||||
struct submodule_alternate_setup *sas = sas_cb;
|
||||
size_t len;
|
||||
|
||||
/*
|
||||
* If the alternate object store is another repository, try the
|
||||
* standard layout with .git/(modules/<name>)+/objects
|
||||
*/
|
||||
if (ends_with(alt->path, "/objects")) {
|
||||
if (strip_suffix(odb->path, "/objects", &len)) {
|
||||
char *sm_alternate;
|
||||
struct strbuf sb = STRBUF_INIT;
|
||||
struct strbuf err = STRBUF_INIT;
|
||||
strbuf_add(&sb, alt->path, strlen(alt->path) - strlen("objects"));
|
||||
strbuf_add(&sb, odb->path, len);
|
||||
|
||||
/*
|
||||
* We need to end the new path with '/' to mark it as a dir,
|
||||
@ -1285,7 +1286,7 @@ static int add_possible_reference_from_superproject(
|
||||
* as the last part of a missing submodule reference would
|
||||
* be taken as a file name.
|
||||
*/
|
||||
strbuf_addf(&sb, "modules/%s/", sas->submodule_name);
|
||||
strbuf_addf(&sb, "/modules/%s/", sas->submodule_name);
|
||||
|
||||
sm_alternate = compute_alternate_path(sb.buf, &err);
|
||||
if (sm_alternate) {
|
||||
|
Reference in New Issue
Block a user