diff options
author | Jonathan Tan <jonathantanmy@google.com> | 2021-06-17 17:13:26 (GMT) |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2021-06-28 16:58:01 (GMT) |
commit | ef830cc4341260ef45ffe6c7164e23505d45a5a2 (patch) | |
tree | 00c3bb9dcaadf183c1b11929a0f5ed9286973ffe /promisor-remote.c | |
parent | d1fa94356ddd2a81348532d49030cd08d0df6a4d (diff) | |
download | git-ef830cc4341260ef45ffe6c7164e23505d45a5a2.zip git-ef830cc4341260ef45ffe6c7164e23505d45a5a2.tar.gz git-ef830cc4341260ef45ffe6c7164e23505d45a5a2.tar.bz2 |
promisor-remote: teach lazy-fetch in any repo
This is one step towards supporting partial clone submodules.
Even after this patch, we will still lack partial clone submodules
support, primarily because a lot of Git code that accesses submodule
objects does so by adding their object stores as alternates, meaning
that any lazy fetches that would occur in the submodule would be done
based on the config of the superproject, not of the submodule. This also
prevents testing of the functionality in this patch by user-facing
commands. So for now, test this mechanism using a test helper.
Besides that, there is some code that uses the wrapper functions
like has_promisor_remote(). Those will need to be checked to see if they
could support the non-wrapper functions instead (and thus support any
repository, not just the_repository).
Signed-off-by: Jonathan Tan <jonathantanmy@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Reviewed-by: Elijah Newren <newren@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'promisor-remote.c')
-rw-r--r-- | promisor-remote.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/promisor-remote.c b/promisor-remote.c index 1e00e16..c088dcb 100644 --- a/promisor-remote.c +++ b/promisor-remote.c @@ -10,7 +10,8 @@ struct promisor_remote_config { struct promisor_remote **promisors_tail; }; -static int fetch_objects(const char *remote_name, +static int fetch_objects(struct repository *repo, + const char *remote_name, const struct object_id *oids, int oid_nr) { @@ -20,6 +21,8 @@ static int fetch_objects(const char *remote_name, child.git_cmd = 1; child.in = -1; + if (repo != the_repository) + prepare_other_repo_env(&child.env_array, repo->gitdir); strvec_pushl(&child.args, "-c", "fetch.negotiationAlgorithm=noop", "fetch", remote_name, "--no-tags", "--no-write-fetch-head", "--recurse-submodules=no", @@ -240,10 +243,8 @@ int promisor_remote_get_direct(struct repository *repo, promisor_remote_init(repo); - if (repo != the_repository) - BUG("only the_repository is supported for now"); for (r = repo->promisor_remote_config->promisors; r; r = r->next) { - if (fetch_objects(r->name, remaining_oids, remaining_nr) < 0) { + if (fetch_objects(repo, r->name, remaining_oids, remaining_nr) < 0) { if (remaining_nr == 1) continue; remaining_nr = remove_fetched_oids(repo, &remaining_oids, |