1 2 3 4 5 6 7 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 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170
/*
* Copyright (c) 2018, 2019 Stefan Sperling <stsp@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
struct got_repository;
struct got_pathlist_head;
struct got_tag_object;
/* Open and close repositories. */
const struct got_error *got_repo_open(struct got_repository**, const char *,
const char *);
const struct got_error *got_repo_close(struct got_repository*);
/* Obtain the on-disk path to the repository. */
const char *got_repo_get_path(struct got_repository *);
/*
* Obtain the path to a non-bare repository's .git directory.
* For bare repositories, this returns the same result as got_repo_get_path().
*/
const char *got_repo_get_path_git_dir(struct got_repository *);
/* Obtain the file descriptor of the repository's .git directory. */
int got_repo_get_fd(struct got_repository *);
/* Obtain the commit author name if parsed from gitconfig, else NULL. */
const char *got_repo_get_gitconfig_author_name(struct got_repository *);
/* Obtain the commit author email if parsed from gitconfig, else NULL. */
const char *got_repo_get_gitconfig_author_email(struct got_repository *);
/* Obtain global commit author name parsed ~/.gitconfig, else NULL. */
const char *got_repo_get_global_gitconfig_author_name(struct got_repository *);
/* Obtain global commit author email parsed ~/.gitconfig, else NULL. */
const char *got_repo_get_global_gitconfig_author_email(struct got_repository *);
/* Obtain repository owner name if parsed from gitconfig, else NULL. */
const char *got_repo_get_gitconfig_owner(struct got_repository *);
/* Information about one remote repository. */
struct got_remote_repo {
char *name;
char *url;
/*
* If set, references are mirrored 1:1 into the local repository.
* If not set, references are mapped into "refs/remotes/$name/".
*/
int mirror_references;
/*
* If set, fetch all branches by default and ignore the list of
* branches below.
*/
int fetch_all_branches;
/* Branches to fetch by default. */
int nbranches;
char **branches;
/* Other arbitrary references to fetch by default. */
int nrefs;
char **refs;
};
/*
* Free data allocated for the specified remote repository.
* Do not free the remote_repo pointer itself.
*/
void got_repo_free_remote_repo_data(struct got_remote_repo *);
/* Obtain the list of remote repositories parsed from gitconfig. */
void got_repo_get_gitconfig_remotes(int *, const struct got_remote_repo **,
struct got_repository *);
/*
* Obtain a parsed representation of this repository's got.conf file.
* Return NULL if this configuration file could not be read.
*/
const struct got_gotconfig *got_repo_get_gotconfig(struct got_repository *);
/*
* Obtain paths to various directories within a repository.
* The caller must dispose of a path with free(3).
*/
char *got_repo_get_path_objects(struct got_repository *);
char *got_repo_get_path_objects_pack(struct got_repository *);
char *got_repo_get_path_refs(struct got_repository *);
char *got_repo_get_path_packed_refs(struct got_repository *);
char *got_repo_get_path_gitconfig(struct got_repository *);
char *got_repo_get_path_gotconfig(struct got_repository *);
struct got_reference;
struct got_reflist_head;
/*
* Obtain a reference, by name, from a repository.
* The caller must dispose of it with got_ref_close().
*/
const struct got_error *got_repo_get_reference(struct got_reference **,
struct got_repository *, const char *);
/* Indicate whether this is a bare repositiry (contains no git working tree). */
int got_repo_is_bare(struct got_repository *);
/* Attempt to map an arbitrary path to a path within the repository. */
const struct got_error *got_repo_map_path(char **, struct got_repository *,
const char *);
/* Create a new repository in an empty directory at a specified path. */
const struct got_error *got_repo_init(const char *);
/* Attempt to find a unique object ID for a given ID string prefix. */
const struct got_error *got_repo_match_object_id_prefix(struct got_object_id **,
const char *, int, struct got_repository *);
/*
* Given an object ID string or reference name, attempt to find a corresponding
* commit object.
* The object type may be restricted to commit, tree, blob, or tag.
* Tags will only be matched if a list of references is provided.
* GOT_OBJ_TYPE_ANY will match any type of object.
* A human-readable label can optionally be returned, which the caller should
* dispose of with free(3).
* Return GOT_ERR_NO_OBJ if no matching commit can be found.
*/
const struct got_error *got_repo_match_object_id(struct got_object_id **,
char **, const char *, int, struct got_reflist_head *,
struct got_repository *);
/*
* Search the provided list of references for a tag with a given name
* and target object type.
* Return GOT_ERR_NO_OBJ if no matching tag can be found.
*/
const struct got_error *got_repo_object_match_tag(struct got_tag_object **,
const char *, int, struct got_reflist_head *, struct got_repository *);
/* A callback function which is invoked when a path is imported. */
typedef const struct got_error *(*got_repo_import_cb)(void *, const char *);
/*
* Import an unversioned directory tree into the repository.
* Creates a root commit, i.e. a commit with zero parents.
*/
const struct got_error *got_repo_import(struct got_object_id **, const char *,
const char *, const char *, struct got_pathlist_head *,
struct got_repository *, got_repo_import_cb, void *);
/* Obtain the number and size of loose objects in the repository. */
const struct got_error *got_repo_get_loose_object_info(int *nobjects,
off_t *ondisk_size, struct got_repository *);
/* Obtain the number and size of packed objects in the repository. */
const struct got_error *got_repo_get_packfile_info(int *npackfiles,
int *nobjects, off_t *total_packsize, struct got_repository *);