repository.h 3.08 KB
Newer Older
1 2 3
#ifndef REPOSITORY_H
#define REPOSITORY_H

4
struct config_set;
5
struct index_state;
6
struct submodule_cache;
7
struct git_hash_algo;
8

9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
struct repository {
	/* Environment */
	/*
	 * Path to the git directory.
	 * Cannot be NULL after initialization.
	 */
	char *gitdir;

	/*
	 * Path to the common git directory.
	 * Cannot be NULL after initialization.
	 */
	char *commondir;

	/*
	 * Path to the repository's object store.
	 * Cannot be NULL after initialization.
	 */
	char *objectdir;

	/*
	 * Path to the repository's graft file.
	 * Cannot be NULL after initialization.
	 */
	char *graft_file;

	/*
	 * Path to the current worktree's index file.
	 * Cannot be NULL after initialization.
	 */
	char *index_file;

	/*
	 * Path to the working directory.
	 * A NULL value indicates that there is no working directory.
	 */
	char *worktree;

47 48 49 50 51 52 53
	/*
	 * Path from the root of the top-level superproject down to this
	 * repository.  This is only non-NULL if the repository is initialized
	 * as a submodule of another repository.
	 */
	char *submodule_prefix;

54 55 56 57 58 59 60 61
	/* Subsystems */
	/*
	 * Repository's config which contains key-value pairs from the usual
	 * set of config files (i.e. repo specific .git/config, user wide
	 * ~/.gitconfig, XDG config file and the global /etc/gitconfig)
	 */
	struct config_set *config;

62 63 64
	/* Repository's submodule config as defined by '.gitmodules' */
	struct submodule_cache *submodule_cache;

65 66 67 68 69 70
	/*
	 * Repository's in-memory index.
	 * 'repo_read_index()' can be used to populate 'index'.
	 */
	struct index_state *index;

71 72 73
	/* Repository's current hash algorithm, as serialized on disk. */
	const struct git_hash_algo *hash_algo;

74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
	/* Configurations */
	/*
	 * Bit used during initialization to indicate if repository state (like
	 * the location of the 'objectdir') should be read from the
	 * environment.  By default this bit will be set at the begining of
	 * 'repo_init()' so that all repositories will ignore the environment.
	 * The exception to this is 'the_repository', which doesn't go through
	 * the normal 'repo_init()' process.
	 */
	unsigned ignore_env:1;

	/* Indicate if a repository has a different 'commondir' from 'gitdir' */
	unsigned different_commondir:1;
};

extern struct repository *the_repository;

extern void repo_set_gitdir(struct repository *repo, const char *path);
extern void repo_set_worktree(struct repository *repo, const char *path);
93
extern void repo_set_hash_algo(struct repository *repo, int algo);
94
extern int repo_init(struct repository *repo, const char *gitdir, const char *worktree);
95 96 97
extern int repo_submodule_init(struct repository *submodule,
			       struct repository *superproject,
			       const char *path);
98 99
extern void repo_clear(struct repository *repo);

100 101 102 103 104 105 106 107
/*
 * Populates the repository's index from its index_file, an index struct will
 * be allocated if needed.
 *
 * Return the number of index entries in the populated index or a value less
 * than zero if an error occured.  If the repository's index has already been
 * populated then the number of entries will simply be returned.
 */
108 109
extern int repo_read_index(struct repository *repo);

110
#endif /* REPOSITORY_H */