Skip to content

Commit

Permalink
refs: store the main ref store inside the repository struct
Browse files Browse the repository at this point in the history
This moves the 'main_ref_store', which was a global variable in refs.c
into the repository struct.

This patch does not deal with the parts in the refs subsystem which deal
with the submodules there. A later patch needs to get rid of the submodule
exposure in the refs API, such as 'get_submodule_ref_store(path)'.

Acked-by: Michael Haggerty <[email protected]>
Signed-off-by: Stefan Beller <[email protected]>
Signed-off-by: Junio C Hamano <[email protected]>
  • Loading branch information
stefanbeller authored and gitster committed Apr 12, 2018
1 parent 1f2e7ce commit 64a7416
Show file tree
Hide file tree
Showing 4 changed files with 9 additions and 15 deletions.
13 changes: 5 additions & 8 deletions refs.c
Original file line number Diff line number Diff line change
Expand Up @@ -1608,9 +1608,6 @@ static struct ref_store_hash_entry *alloc_ref_store_hash_entry(
return entry;
}

/* A pointer to the ref_store for the main repository: */
static struct ref_store *main_ref_store;

/* A hashmap of ref_stores, stored by submodule name: */
static struct hashmap submodule_ref_stores;

Expand Down Expand Up @@ -1652,13 +1649,13 @@ static struct ref_store *ref_store_init(const char *gitdir,
return refs;
}

struct ref_store *get_main_ref_store_the_repository(void)
struct ref_store *get_main_ref_store(struct repository *r)
{
if (main_ref_store)
return main_ref_store;
if (r->refs)
return r->refs;

main_ref_store = ref_store_init(get_git_dir(), REF_STORE_ALL_CAPS);
return main_ref_store;
r->refs = ref_store_init(r->gitdir, REF_STORE_ALL_CAPS);
return r->refs;
}

/*
Expand Down
4 changes: 1 addition & 3 deletions refs.h
Original file line number Diff line number Diff line change
Expand Up @@ -760,9 +760,7 @@ int reflog_expire(const char *refname, const struct object_id *oid,

int ref_storage_backend_exists(const char *name);

#define get_main_ref_store(r) \
get_main_ref_store_##r()
struct ref_store *get_main_ref_store_the_repository(void);
struct ref_store *get_main_ref_store(struct repository *r);
/*
* Return the ref_store instance for the specified submodule. For the
* main repository, use submodule==NULL; such a call cannot fail. For
Expand Down
4 changes: 0 additions & 4 deletions refs/files-backend.c
Original file line number Diff line number Diff line change
Expand Up @@ -61,10 +61,6 @@ struct ref_lock {
struct object_id old_oid;
};

/*
* Future: need to be in "struct repository"
* when doing a full libification.
*/
struct files_ref_store {
struct ref_store base;
unsigned int store_flags;
Expand Down
3 changes: 3 additions & 0 deletions repository.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,9 @@ struct repository {
*/
struct raw_object_store *objects;

/* The store in which the refs are held. */
struct ref_store *refs;

/*
* Path to the repository's graft file.
* Cannot be NULL after initialization.
Expand Down

0 comments on commit 64a7416

Please sign in to comment.