Instead of using the repository_format_partial_clone global
and fetch_object() directly, let's use has_odb_remote() and
odb_remote_get_direct().

Signed-off-by: Christian Couder <chrisc...@tuxfamily.org>
---
 builtin/cat-file.c            |  5 +++--
 builtin/fetch.c               | 11 ++++++-----
 builtin/gc.c                  |  3 ++-
 builtin/repack.c              |  3 ++-
 cache.h                       |  2 --
 connected.c                   |  3 ++-
 environment.c                 |  1 -
 list-objects-filter-options.c | 27 +++++++++++++++------------
 packfile.c                    |  3 ++-
 setup.c                       |  7 +------
 sha1-file.c                   |  9 +++++----
 t/t0410-partial-clone.sh      | 30 +++++++++++++++---------------
 t/t5500-fetch-pack.sh         |  4 ++--
 t/t5601-clone.sh              |  2 +-
 t/t5616-partial-clone.sh      |  2 +-
 unpack-trees.c                |  6 +++---
 16 files changed, 60 insertions(+), 58 deletions(-)

diff --git a/builtin/cat-file.c b/builtin/cat-file.c
index 2c46d257cd..25665b206a 100644
--- a/builtin/cat-file.c
+++ b/builtin/cat-file.c
@@ -13,6 +13,7 @@
 #include "tree-walk.h"
 #include "sha1-array.h"
 #include "packfile.h"
+#include "odb-remote.h"
 
 struct batch_options {
        int enabled;
@@ -477,8 +478,8 @@ static int batch_objects(struct batch_options *opt)
 
                for_each_loose_object(batch_loose_object, &sa, 0);
                for_each_packed_object(batch_packed_object, &sa, 0);
-               if (repository_format_partial_clone)
-                       warning("This repository has extensions.partialClone 
set. Some objects may not be loaded.");
+               if (has_odb_remote())
+                       warning("This repository uses an odb. Some objects may 
not be loaded.");
 
                cb.opt = opt;
                cb.expand = &data;
diff --git a/builtin/fetch.c b/builtin/fetch.c
index 7ee83ac0f8..82a3e655ba 100644
--- a/builtin/fetch.c
+++ b/builtin/fetch.c
@@ -20,6 +20,7 @@
 #include "utf8.h"
 #include "packfile.h"
 #include "list-objects-filter-options.h"
+#include "odb-remote.h"
 
 static const char * const builtin_fetch_usage[] = {
        N_("git fetch [<options>] [<repository> [<refspec>...]]"),
@@ -1320,7 +1321,7 @@ static inline void fetch_one_setup_partial(struct remote 
*remote)
         * If no prior partial clone/fetch and the current fetch DID NOT
         * request a partial-fetch, do a normal fetch.
         */
-       if (!repository_format_partial_clone && !filter_options.choice)
+       if (!has_odb_remote() && !filter_options.choice)
                return;
 
        /*
@@ -1328,7 +1329,7 @@ static inline void fetch_one_setup_partial(struct remote 
*remote)
         * on this repo and remember the given filter-spec as the default
         * for subsequent fetches to this remote.
         */
-       if (!repository_format_partial_clone && filter_options.choice) {
+       if (!has_odb_remote() && filter_options.choice) {
                partial_clone_register(remote->name, &filter_options);
                return;
        }
@@ -1337,7 +1338,7 @@ static inline void fetch_one_setup_partial(struct remote 
*remote)
         * We are currently limited to only ONE promisor remote and only
         * allow partial-fetches from the promisor remote.
         */
-       if (strcmp(remote->name, repository_format_partial_clone)) {
+       if (!find_odb_helper(remote->name)) {
                if (filter_options.choice)
                        die(_("--filter can only be used with the remote 
configured in core.partialClone"));
                return;
@@ -1473,7 +1474,7 @@ int cmd_fetch(int argc, const char **argv, const char 
*prefix)
        if (depth || deepen_since || deepen_not.nr)
                deepen = 1;
 
-       if (filter_options.choice && !repository_format_partial_clone)
+       if (filter_options.choice && !has_odb_remote())
                die("--filter can only be used when extensions.partialClone is 
set");
 
        if (all) {
@@ -1507,7 +1508,7 @@ int cmd_fetch(int argc, const char **argv, const char 
*prefix)
        }
 
        if (remote) {
-               if (filter_options.choice || repository_format_partial_clone)
+               if (filter_options.choice || has_odb_remote())
                        fetch_one_setup_partial(remote);
                result = fetch_one(remote, argc, argv, prune_tags_ok);
        } else {
diff --git a/builtin/gc.c b/builtin/gc.c
index d604940bb6..418cf2f0b0 100644
--- a/builtin/gc.c
+++ b/builtin/gc.c
@@ -22,6 +22,7 @@
 #include "commit.h"
 #include "packfile.h"
 #include "object-store.h"
+#include "odb-remote.h"
 
 #define FAILED_RUN "failed to run %s"
 
@@ -466,7 +467,7 @@ int cmd_gc(int argc, const char **argv, const char *prefix)
                        argv_array_push(&prune, prune_expire);
                        if (quiet)
                                argv_array_push(&prune, "--no-progress");
-                       if (repository_format_partial_clone)
+                       if (has_odb_remote())
                                argv_array_push(&prune,
                                                "--exclude-promisor-objects");
                        if (run_command_v_opt(prune.argv, RUN_GIT_CMD))
diff --git a/builtin/repack.c b/builtin/repack.c
index 7bdb40142f..8d2126087b 100644
--- a/builtin/repack.c
+++ b/builtin/repack.c
@@ -8,6 +8,7 @@
 #include "strbuf.h"
 #include "string-list.h"
 #include "argv-array.h"
+#include "odb-remote.h"
 
 static int delta_base_offset = 1;
 static int pack_kept_objects = -1;
@@ -234,7 +235,7 @@ int cmd_repack(int argc, const char **argv, const char 
*prefix)
        argv_array_push(&cmd.args, "--all");
        argv_array_push(&cmd.args, "--reflog");
        argv_array_push(&cmd.args, "--indexed-objects");
-       if (repository_format_partial_clone)
+       if (has_odb_remote())
                argv_array_push(&cmd.args, "--exclude-promisor-objects");
        if (window)
                argv_array_pushf(&cmd.args, "--window=%s", window);
diff --git a/cache.h b/cache.h
index 0c1fb9fbcc..17263f9013 100644
--- a/cache.h
+++ b/cache.h
@@ -897,13 +897,11 @@ extern int grafts_replace_parents;
 #define GIT_REPO_VERSION 0
 #define GIT_REPO_VERSION_READ 1
 extern int repository_format_precious_objects;
-extern char *repository_format_partial_clone;
 extern const char *core_partial_clone_filter_default;
 
 struct repository_format {
        int version;
        int precious_objects;
-       char *partial_clone; /* value of extensions.partialclone */
        int is_bare;
        int hash_algo;
        char *work_tree;
diff --git a/connected.c b/connected.c
index 91feb78815..5d45f833d4 100644
--- a/connected.c
+++ b/connected.c
@@ -4,6 +4,7 @@
 #include "connected.h"
 #include "transport.h"
 #include "packfile.h"
+#include "odb-remote.h"
 
 /*
  * If we feed all the commits we want to verify to this command
@@ -56,7 +57,7 @@ int check_connected(oid_iterate_fn fn, void *cb_data,
        argv_array_push(&rev_list.args,"rev-list");
        argv_array_push(&rev_list.args, "--objects");
        argv_array_push(&rev_list.args, "--stdin");
-       if (repository_format_partial_clone)
+       if (has_odb_remote())
                argv_array_push(&rev_list.args, "--exclude-promisor-objects");
        argv_array_push(&rev_list.args, "--not");
        argv_array_push(&rev_list.args, "--all");
diff --git a/environment.c b/environment.c
index 2a6de2330b..f8048f4a5d 100644
--- a/environment.c
+++ b/environment.c
@@ -30,7 +30,6 @@ int warn_ambiguous_refs = 1;
 int warn_on_object_refname_ambiguity = 1;
 int ref_paranoia = -1;
 int repository_format_precious_objects;
-char *repository_format_partial_clone;
 const char *core_partial_clone_filter_default;
 const char *git_commit_encoding;
 const char *git_log_output_encoding;
diff --git a/list-objects-filter-options.c b/list-objects-filter-options.c
index 6a3cc985c4..f8a4642d17 100644
--- a/list-objects-filter-options.c
+++ b/list-objects-filter-options.c
@@ -6,6 +6,7 @@
 #include "list-objects.h"
 #include "list-objects-filter.h"
 #include "list-objects-filter-options.h"
+#include "odb-remote.h"
 
 /*
  * Parse value of the argument to the "filter" keyword.
@@ -114,30 +115,32 @@ void partial_clone_register(
        const char *remote,
        const struct list_objects_filter_options *filter_options)
 {
-       /*
-        * Record the name of the partial clone remote in the
-        * config and in the global variable -- the latter is
-        * used throughout to indicate that partial clone is
-        * enabled and to expect missing objects.
-        */
-       if (repository_format_partial_clone &&
-           *repository_format_partial_clone &&
-           strcmp(remote, repository_format_partial_clone))
-               die(_("cannot change partial clone promisor remote"));
+       char *cfg_name;
+
+       /* Check if it is already registered */
+       if (find_odb_helper(remote))
+               return;
 
        git_config_set("core.repositoryformatversion", "1");
-       git_config_set("extensions.partialclone", remote);
 
-       repository_format_partial_clone = xstrdup(remote);
+       /* Add odb config for the remote */
+       cfg_name = xstrfmt("odb.%s.promisorRemote", remote);
+       git_config_set(cfg_name, remote);
+       free(cfg_name);
 
        /*
         * Record the initial filter-spec in the config as
         * the default for subsequent fetches from this remote.
+        *
+        * TODO: move core.partialclonefilter into odb.<name>
         */
        core_partial_clone_filter_default =
                xstrdup(filter_options->filter_spec);
        git_config_set("core.partialclonefilter",
                       core_partial_clone_filter_default);
+
+       /* Make sure the config info are reset */
+       odb_remote_reinit();
 }
 
 void partial_clone_get_default_filter_spec(
diff --git a/packfile.c b/packfile.c
index 6c3ddc3c31..bf0d1e7a20 100644
--- a/packfile.c
+++ b/packfile.c
@@ -15,6 +15,7 @@
 #include "tree-walk.h"
 #include "tree.h"
 #include "object-store.h"
+#include "odb-remote.h"
 
 char *odb_pack_name(struct strbuf *buf,
                    const unsigned char *sha1,
@@ -1960,7 +1961,7 @@ int is_promisor_object(const struct object_id *oid)
        static int promisor_objects_prepared;
 
        if (!promisor_objects_prepared) {
-               if (repository_format_partial_clone) {
+               if (has_odb_remote()) {
                        for_each_packed_object(add_promisor_object,
                                               &promisor_objects,
                                               FOR_EACH_OBJECT_PROMISOR_ONLY);
diff --git a/setup.c b/setup.c
index 3e03d442b6..be7f45cf4b 100644
--- a/setup.c
+++ b/setup.c
@@ -419,11 +419,7 @@ static int check_repo_format(const char *var, const char 
*value, void *vdata)
                        ;
                else if (!strcmp(ext, "preciousobjects"))
                        data->precious_objects = git_config_bool(var, value);
-               else if (!strcmp(ext, "partialclone")) {
-                       if (!value)
-                               return config_error_nonbool(var);
-                       data->partial_clone = xstrdup(value);
-               } else
+               else
                        string_list_append(&data->unknown_extensions, ext);
        } else if (strcmp(var, "core.bare") == 0) {
                data->is_bare = git_config_bool(var, value);
@@ -465,7 +461,6 @@ static int check_repository_format_gently(const char 
*gitdir, struct repository_
        }
 
        repository_format_precious_objects = candidate->precious_objects;
-       repository_format_partial_clone = candidate->partial_clone;
        string_list_clear(&candidate->unknown_extensions, 0);
        if (!has_common) {
                if (candidate->is_bare != -1) {
diff --git a/sha1-file.c b/sha1-file.c
index 7d3c1ebd91..27eb3a99ac 100644
--- a/sha1-file.c
+++ b/sha1-file.c
@@ -32,6 +32,7 @@
 #include "packfile.h"
 #include "fetch-object.h"
 #include "object-store.h"
+#include "odb-remote.h"
 
 /* The maximum size for an object header. */
 #define MAX_HEADER_LEN 32
@@ -1287,13 +1288,13 @@ int oid_object_info_extended(const struct object_id 
*oid, struct object_info *oi
                }
 
                /* Check if it is a missing object */
-               if (fetch_if_missing && repository_format_partial_clone &&
+               if (fetch_if_missing && has_odb_remote() &&
                    !already_retried) {
                        /*
-                        * TODO Investigate checking fetch_object() return
-                        * TODO value and stopping on error here.
+                        * TODO Investigate checking odb_remote_get_direct()
+                        * TODO return value and stopping on error here.
                         */
-                       fetch_object(repository_format_partial_clone, 
real->hash);
+                       odb_remote_get_direct(real->hash);
                        already_retried = 1;
                        continue;
                }
diff --git a/t/t0410-partial-clone.sh b/t/t0410-partial-clone.sh
index cc18b75c03..6af4712da8 100755
--- a/t/t0410-partial-clone.sh
+++ b/t/t0410-partial-clone.sh
@@ -43,7 +43,7 @@ test_expect_success 'missing reflog object, but promised by a 
commit, passes fsc
 
        # But with the extension, it succeeds
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo fsck
 '
 
@@ -66,7 +66,7 @@ test_expect_success 'missing reflog object, but promised by a 
tag, passes fsck'
        printf "$T\n" | pack_as_from_promisor &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo fsck
 '
 
@@ -84,7 +84,7 @@ test_expect_success 'missing reflog object alone fails fsck, 
even with extension
        delete_object repo "$A" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        test_must_fail git -C repo fsck
 '
 
@@ -100,7 +100,7 @@ test_expect_success 'missing ref object, but promised, 
passes fsck' '
        promise_and_delete "$A" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo fsck
 '
 
@@ -123,7 +123,7 @@ test_expect_success 'missing object, but promised, passes 
fsck' '
        promise_and_delete "$AT" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo fsck
 '
 
@@ -136,7 +136,7 @@ test_expect_success 'missing CLI object, but promised, 
passes fsck' '
        promise_and_delete "$A" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo fsck "$A"
 '
 
@@ -151,7 +151,7 @@ test_expect_success 'fetching of missing objects' '
        rm -rf repo/.git/objects/* &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "origin" &&
+       git -C repo config odb.magic.promisorRemote "origin" &&
        git -C repo cat-file -p "$HASH" &&
 
        # Ensure that the .promisor file is written, and check that its
@@ -172,7 +172,7 @@ test_expect_success 'rev-list stops traversal at missing 
and promised commit' '
        promise_and_delete "$FOO" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo rev-list --exclude-promisor-objects --objects bar >out &&
        grep $(git -C repo rev-parse bar) out &&
        ! grep $FOO out
@@ -197,7 +197,7 @@ test_expect_success 'rev-list stops traversal at missing 
and promised tree' '
        promise_and_delete "$TREE2" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo rev-list --exclude-promisor-objects --objects HEAD >out &&
        grep $(git -C repo rev-parse foo) out &&
        ! grep $TREE out &&
@@ -216,7 +216,7 @@ test_expect_success 'rev-list stops traversal at missing 
and promised blob' '
        promise_and_delete "$BLOB" &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo rev-list --exclude-promisor-objects --objects HEAD >out &&
        grep $(git -C repo rev-parse HEAD) out &&
        ! grep $BLOB out
@@ -235,7 +235,7 @@ test_expect_success 'rev-list stops traversal at promisor 
commit, tree, and blob
        printf "%s\n%s\n%s\n" $COMMIT $TREE $BLOB | pack_as_from_promisor &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo rev-list --exclude-promisor-objects --objects HEAD >out &&
        ! grep $COMMIT out &&
        ! grep $TREE out &&
@@ -259,7 +259,7 @@ test_expect_success 'rev-list accepts missing and promised 
objects on command li
        promise_and_delete $BLOB &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo rev-list --exclude-promisor-objects --objects "$COMMIT" 
"$TREE" "$BLOB"
 '
 
@@ -272,7 +272,7 @@ test_expect_success 'gc does not repack promisor objects' '
        HASH=$(printf "$TREE_HASH\n" | pack_as_from_promisor) &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo gc &&
 
        # Ensure that the promisor packfile still exists, and remove it
@@ -296,7 +296,7 @@ test_expect_success 'gc stops traversal when a missing but 
promised object is re
        HASH=$(promise_and_delete $TREE_HASH) &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "arbitrary string" &&
+       git -C repo config odb.magic.promisorRemote "arbitrary string" &&
        git -C repo gc &&
 
        # Ensure that the promisor packfile still exists, and remove it
@@ -327,7 +327,7 @@ test_expect_success 'fetching of missing objects from an 
HTTP server' '
        rm -rf repo/.git/objects/* &&
 
        git -C repo config core.repositoryformatversion 1 &&
-       git -C repo config extensions.partialclone "origin" &&
+       git -C repo config odb.magic.promisorRemote "origin" &&
        git -C repo cat-file -p "$HASH" &&
 
        # Ensure that the .promisor file is written, and check that its
diff --git a/t/t5500-fetch-pack.sh b/t/t5500-fetch-pack.sh
index 0680dec808..3bb20b0566 100755
--- a/t/t5500-fetch-pack.sh
+++ b/t/t5500-fetch-pack.sh
@@ -792,14 +792,14 @@ fetch_filter_blob_limit_zero () {
        test_config -C "$SERVER" uploadpack.allowfilter 1 &&
 
        git clone "$URL" client &&
-       test_config -C client extensions.partialclone origin &&
+       test_config -C client odb.magic.promisorRemote origin &&
 
        test_commit -C "$SERVER" two &&
 
        git -C client fetch --filter=blob:limit=0 origin HEAD:somewhere &&
 
        # Ensure that commit is fetched, but blob is not
-       test_config -C client extensions.partialclone "arbitrary string" &&
+       test_config -C client odb.magic.promisorRemote "arbitrary string" &&
        git -C client cat-file -e $(git -C "$SERVER" rev-parse two) &&
        test_must_fail git -C client cat-file -e $(git hash-object 
"$SERVER/two.t")
 }
diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh
index 0b62037744..022c65a7ae 100755
--- a/t/t5601-clone.sh
+++ b/t/t5601-clone.sh
@@ -647,7 +647,7 @@ partial_clone () {
        git -C client fsck &&
 
        # Ensure that unneeded blobs are not inadvertently fetched.
-       test_config -C client extensions.partialclone "not a remote" &&
+       test_config -C client odb.origin.promisorRemote "not a remote" &&
        test_must_fail git -C client cat-file -e "$HASH1" &&
 
        # But this blob was fetched, because clone performs an initial checkout
diff --git a/t/t5616-partial-clone.sh b/t/t5616-partial-clone.sh
index cee5565367..5ddd1e011c 100755
--- a/t/t5616-partial-clone.sh
+++ b/t/t5616-partial-clone.sh
@@ -40,7 +40,7 @@ test_expect_success 'do partial clone 1' '
                | sort >observed.oids &&
        test_cmp expect_1.oids observed.oids &&
        test "$(git -C pc1 config --local core.repositoryformatversion)" = "1" 
&&
-       test "$(git -C pc1 config --local extensions.partialclone)" = "origin" 
&&
+       test "$(git -C pc1 config --local odb.origin.promisorRemote)" = 
"origin" &&
        test "$(git -C pc1 config --local core.partialclonefilter)" = 
"blob:none"
 '
 
diff --git a/unpack-trees.c b/unpack-trees.c
index dec37ad1e7..fde63993a9 100644
--- a/unpack-trees.c
+++ b/unpack-trees.c
@@ -16,6 +16,7 @@
 #include "submodule-config.h"
 #include "fsmonitor.h"
 #include "fetch-object.h"
+#include "odb-remote.h"
 
 /*
  * Error messages expected by scripts out of plumbing commands such as
@@ -371,7 +372,7 @@ static int check_updates(struct unpack_trees_options *o)
                load_gitmodules_file(index, &state);
 
        enable_delayed_checkout(&state);
-       if (repository_format_partial_clone && o->update && !o->dry_run) {
+       if (has_odb_remote() && o->update && !o->dry_run) {
                /*
                 * Prefetch the objects that are to be checked out in the loop
                 * below.
@@ -388,8 +389,7 @@ static int check_updates(struct unpack_trees_options *o)
                        }
                }
                if (to_fetch.nr)
-                       fetch_objects(repository_format_partial_clone,
-                                     &to_fetch);
+                       odb_remote_get_many_direct(&to_fetch);
                fetch_if_missing = fetch_if_missing_store;
                oid_array_clear(&to_fetch);
        }
-- 
2.17.0.590.gbd05bfcafd

Reply via email to