]> git.ipfire.org Git - thirdparty/git.git/commitdiff
refs: centralize initialization of the base ref_store.
authorHan-Wen Nienhuys <hanwen@google.com>
Wed, 22 Dec 2021 18:11:54 +0000 (18:11 +0000)
committerJunio C Hamano <gitster@pobox.com>
Wed, 22 Dec 2021 21:51:38 +0000 (13:51 -0800)
Signed-off-by: Han-Wen Nienhuys <hanwen@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
refs.c
refs/debug.c
refs/files-backend.c
refs/packed-backend.c
refs/refs-internal.h

diff --git a/refs.c b/refs.c
index 4c317955813a67222be95c16b337cb55f1a07326..f91edb7307520cf07b7f6d6a41a1b4ed50a0a3a0 100644 (file)
--- a/refs.c
+++ b/refs.c
@@ -2007,10 +2007,12 @@ struct ref_store *get_worktree_ref_store(const struct worktree *wt)
        return refs;
 }
 
-void base_ref_store_init(struct ref_store *refs,
-                        const struct ref_storage_be *be)
+void base_ref_store_init(struct ref_store *refs, struct repository *repo,
+                        const char *path, const struct ref_storage_be *be)
 {
        refs->be = be;
+       refs->repo = repo;
+       refs->gitdir = xstrdup(path);
 }
 
 /* backend functions */
index 8a6bb157ee67a83e9f9916c3921c346b67450940..2b0771ca53b7854c46ab231b22ecf8be919ca19a 100644 (file)
@@ -26,7 +26,8 @@ struct ref_store *maybe_debug_wrap_ref_store(const char *gitdir, struct ref_stor
        be_copy->name = store->be->name;
        trace_printf_key(&trace_refs, "ref_store for %s\n", gitdir);
        res->refs = store;
-       base_ref_store_init((struct ref_store *)res, be_copy);
+       base_ref_store_init((struct ref_store *)res, store->repo, gitdir,
+                           be_copy);
        return (struct ref_store *)res;
 }
 
index f1b66130dfb48e28fa6a888b01fa5e16781f7ea5..5c6d49a267e7f91e74ca0b4149f20d5ca64f3317 100644 (file)
@@ -86,11 +86,8 @@ static struct ref_store *files_ref_store_create(struct repository *repo,
        struct ref_store *ref_store = (struct ref_store *)refs;
        struct strbuf sb = STRBUF_INIT;
 
-       ref_store->repo = repo;
-       ref_store->gitdir = xstrdup(gitdir);
-       base_ref_store_init(ref_store, &refs_be_files);
+       base_ref_store_init(ref_store, repo, gitdir, &refs_be_files);
        refs->store_flags = flags;
-
        get_common_dir_noenv(&sb, gitdir);
        refs->gitcommondir = strbuf_detach(&sb, NULL);
        refs->packed_ref_store =
index caa1957252aae739ae09277c56df3542f1e301d4..d91a2018f6011d6c8e79a97e5742baa3c32a9f4a 100644 (file)
@@ -201,13 +201,11 @@ struct ref_store *packed_ref_store_create(struct repository *repo,
        struct ref_store *ref_store = (struct ref_store *)refs;
        struct strbuf sb = STRBUF_INIT;
 
-       base_ref_store_init(ref_store, &refs_be_packed);
-       ref_store->repo = repo;
-       ref_store->gitdir = xstrdup(gitdir);
+       base_ref_store_init(ref_store, repo, gitdir, &refs_be_packed);
        refs->store_flags = store_flags;
+
        strbuf_addf(&sb, "%s/packed-refs", gitdir);
        refs->path = strbuf_detach(&sb, NULL);
-
        chdir_notify_reparent("packed-refs", &refs->path);
        return ref_store;
 }
index 46a839539e33451f7debc980a1a23744a7094d05..7ff6fba4f0d3ef138525edf6fd5b9511e2cfe07d 100644 (file)
@@ -710,8 +710,8 @@ int parse_loose_ref_contents(const char *buf, struct object_id *oid,
  * Fill in the generic part of refs and add it to our collection of
  * reference stores.
  */
-void base_ref_store_init(struct ref_store *refs,
-                        const struct ref_storage_be *be);
+void base_ref_store_init(struct ref_store *refs, struct repository *repo,
+                        const char *path, const struct ref_storage_be *be);
 
 /*
  * Support GIT_TRACE_REFS by optionally wrapping the given ref_store instance.