blob: 312b7ca131c459faeae32ff5cf3021c6516eb2af [file] [log] [blame]
Daniel Barkalow5751f492007-05-12 11:45:53 -04001#ifndef REMOTE_H
2#define REMOTE_H
3
Junio C Hamano28f5d172013-07-08 15:34:36 -07004#include "parse-options.h"
Patrick Reynoldsd0da0032014-07-29 14:43:39 +00005#include "hashmap.h"
Junio C Hamano28f5d172013-07-08 15:34:36 -07006
Miklos Vajna89cf4c72008-11-10 21:43:00 +01007enum {
8 REMOTE_CONFIG,
9 REMOTE_REMOTES,
10 REMOTE_BRANCHES
11};
12
Daniel Barkalow5751f492007-05-12 11:45:53 -040013struct remote {
Patrick Reynoldsd0da0032014-07-29 14:43:39 +000014 struct hashmap_entry ent; /* must be first */
15
Daniel Barkalow5751f492007-05-12 11:45:53 -040016 const char *name;
Miklos Vajna89cf4c72008-11-10 21:43:00 +010017 int origin;
Daniel Barkalow5751f492007-05-12 11:45:53 -040018
Daniel Barkalowc578f512009-11-18 02:42:25 +010019 const char *foreign_vcs;
20
Shawn O. Pearce28b91f82007-09-19 00:49:27 -040021 const char **url;
22 int url_nr;
Daniel Barkalow2d313472008-02-18 23:41:41 -050023 int url_alloc;
Daniel Barkalow5751f492007-05-12 11:45:53 -040024
Michael J Gruber20346232009-06-09 18:01:34 +020025 const char **pushurl;
26 int pushurl_nr;
27 int pushurl_alloc;
28
Daniel Barkalow5751f492007-05-12 11:45:53 -040029 const char **push_refspec;
Daniel Barkalow6b628162007-05-12 11:45:59 -040030 struct refspec *push;
Daniel Barkalow5751f492007-05-12 11:45:53 -040031 int push_refspec_nr;
Daniel Barkalow2d313472008-02-18 23:41:41 -050032 int push_refspec_alloc;
Daniel Barkalow5751f492007-05-12 11:45:53 -040033
Daniel Barkalow5d46c9d2007-05-12 11:46:03 -040034 const char **fetch_refspec;
35 struct refspec *fetch;
36 int fetch_refspec_nr;
Daniel Barkalow2d313472008-02-18 23:41:41 -050037 int fetch_refspec_alloc;
Daniel Barkalow5d46c9d2007-05-12 11:46:03 -040038
Daniel Barkalowd71ab172007-09-10 23:03:08 -040039 /*
40 * -1 to never fetch tags
41 * 0 to auto-follow tags on heuristic (default)
42 * 1 to always auto-follow tags
43 * 2 to always fetch tags
44 */
45 int fetch_tags;
Johannes Schindelin211c8962008-02-29 01:45:45 +000046 int skip_default_update;
Paolo Bonzini84bb2df2008-04-17 13:17:20 +020047 int mirror;
Michael Schubert737c5a92013-07-13 11:36:24 +020048 int prune;
Daniel Barkalowd71ab172007-09-10 23:03:08 -040049
Daniel Barkalow5751f492007-05-12 11:45:53 -040050 const char *receivepack;
Daniel Barkalow0012ba22007-09-10 23:02:51 -040051 const char *uploadpack;
Sam Vilain14c98212007-12-04 10:48:54 +130052
53 /*
54 * for curl remotes only
55 */
56 char *http_proxy;
Daniel Barkalow5751f492007-05-12 11:45:53 -040057};
58
59struct remote *remote_get(const char *name);
Ramkumar Ramachandraf24f7152013-04-02 13:10:32 +053060struct remote *pushremote_get(const char *name);
Finn Arne Gangstad9a23ba32009-04-06 15:41:01 +020061int remote_is_configured(const char *name);
Daniel Barkalow5751f492007-05-12 11:45:53 -040062
Johannes Schindelinb42f6922007-07-10 18:48:40 +010063typedef int each_remote_fn(struct remote *remote, void *priv);
64int for_each_remote(each_remote_fn fn, void *priv);
65
Shawn O. Pearce28b91f82007-09-19 00:49:27 -040066int remote_has_url(struct remote *remote, const char *url);
Daniel Barkalow5d46c9d2007-05-12 11:46:03 -040067
Daniel Barkalow6b628162007-05-12 11:45:59 -040068struct refspec {
69 unsigned force : 1;
70 unsigned pattern : 1;
Paolo Bonzinia83619d2008-04-28 11:32:12 -040071 unsigned matching : 1;
Junio C Hamano6e7b66e2013-01-29 14:02:15 -080072 unsigned exact_sha1 : 1;
Daniel Barkalow6b628162007-05-12 11:45:59 -040073
Johannes Schindelinb42f6922007-07-10 18:48:40 +010074 char *src;
Daniel Barkalow6b628162007-05-12 11:45:59 -040075 char *dst;
76};
77
Daniel Barkalowe0aaa292008-04-17 19:32:35 -040078extern const struct refspec *tag_refspec;
79
Junio C Hamano47a59182013-07-08 13:56:53 -070080struct ref {
81 struct ref *next;
82 unsigned char old_sha1[20];
83 unsigned char new_sha1[20];
Junio C Hamano91048a92013-07-09 11:01:06 -070084 unsigned char old_sha1_expect[20]; /* used by expect-old */
Junio C Hamano47a59182013-07-08 13:56:53 -070085 char *symref;
86 unsigned int
87 force:1,
88 forced_update:1,
Junio C Hamano91048a92013-07-09 11:01:06 -070089 expect_old_sha1:1,
90 expect_old_no_trackback:1,
Junio C Hamano47a59182013-07-08 13:56:53 -070091 deletion:1,
92 matched:1;
93
94 /*
95 * Order is important here, as we write to FETCH_HEAD
96 * in numeric order. And the default NOT_FOR_MERGE
97 * should be 0, so that xcalloc'd structures get it
98 * by default.
99 */
100 enum {
101 FETCH_HEAD_MERGE = -1,
102 FETCH_HEAD_NOT_FOR_MERGE = 0,
103 FETCH_HEAD_IGNORE = 1
104 } fetch_head_status;
105
106 enum {
107 REF_STATUS_NONE = 0,
108 REF_STATUS_OK,
109 REF_STATUS_REJECT_NONFASTFORWARD,
110 REF_STATUS_REJECT_ALREADY_EXISTS,
111 REF_STATUS_REJECT_NODELETE,
112 REF_STATUS_REJECT_FETCH_FIRST,
113 REF_STATUS_REJECT_NEEDS_FORCE,
Junio C Hamano631b5ef2013-07-08 14:42:40 -0700114 REF_STATUS_REJECT_STALE,
Nguyễn Thái Ngọc Duy4820a332013-12-05 20:02:40 +0700115 REF_STATUS_REJECT_SHALLOW,
Junio C Hamano47a59182013-07-08 13:56:53 -0700116 REF_STATUS_UPTODATE,
117 REF_STATUS_REMOTE_REJECT,
Ronnie Sahlberg4ff17f12015-01-07 19:23:22 -0800118 REF_STATUS_EXPECTING_REPORT,
119 REF_STATUS_ATOMIC_PUSH_FAILED
Junio C Hamano47a59182013-07-08 13:56:53 -0700120 } status;
121 char *remote_status;
122 struct ref *peer_ref; /* when renaming */
123 char name[FLEX_ARRAY]; /* more */
124};
125
126#define REF_NORMAL (1u << 0)
127#define REF_HEADS (1u << 1)
128#define REF_TAGS (1u << 2)
129
130extern struct ref *find_ref_by_name(const struct ref *list, const char *name);
131
René Scharfe59c69c02008-10-18 10:44:18 +0200132struct ref *alloc_ref(const char *name);
Jeff King59a57752011-06-07 19:03:03 -0400133struct ref *copy_ref(const struct ref *ref);
Daniel Barkalow45773702007-10-29 21:05:40 -0400134struct ref *copy_ref_list(const struct ref *ref);
Jeff Kinged81c762012-05-21 18:19:28 -0400135void sort_ref_list(struct ref **, int (*cmp)(const void *, const void *));
Junio C Hamanoca024652013-12-03 15:41:15 -0800136extern int count_refspec_match(const char *, struct ref *refs, struct ref **matched_ref);
Jeff Kinged81c762012-05-21 18:19:28 -0400137int ref_compare_name(const void *, const void *);
Daniel Barkalow45773702007-10-29 21:05:40 -0400138
139int check_ref_type(const struct ref *ref, int flags);
140
Daniel Barkalowdfd255d2007-07-10 00:47:23 -0400141/*
142 * Frees the entire list and peers of elements.
143 */
144void free_refs(struct ref *ref);
145
Nguyễn Thái Ngọc Duy13eb4622013-12-05 20:02:29 +0700146struct sha1_array;
Junio C Hamano47a59182013-07-08 13:56:53 -0700147extern struct ref **get_remote_heads(int in, char *src_buf, size_t src_len,
148 struct ref **list, unsigned int flags,
Nguyễn Thái Ngọc Duyb06dcd72013-12-05 20:02:33 +0700149 struct sha1_array *extra_have,
150 struct sha1_array *shallow);
Junio C Hamano47a59182013-07-08 13:56:53 -0700151
Daniel Barkalowbe885d92008-04-26 15:53:12 -0400152int resolve_remote_symref(struct ref *ref, struct ref *list);
Jay Soffianec8452d2009-02-25 03:32:12 -0500153int ref_newer(const unsigned char *new_sha1, const unsigned char *old_sha1);
Daniel Barkalowbe885d92008-04-26 15:53:12 -0400154
Daniel Barkalow2467a4f2007-10-08 00:25:07 -0400155/*
Michael Haggertyb9afe662013-10-30 06:33:09 +0100156 * Remove and free all but the first of any entries in the input list
157 * that map the same remote reference to the same local reference. If
158 * there are two entries that map different remote references to the
159 * same local reference, emit an error message and die. Return a
160 * pointer to the head of the resulting list.
Daniel Barkalow2467a4f2007-10-08 00:25:07 -0400161 */
Michael Haggertyb9afe662013-10-30 06:33:09 +0100162struct ref *ref_remove_duplicates(struct ref *ref_map);
Daniel Barkalow2467a4f2007-10-08 00:25:07 -0400163
Jonas Fonseca24b61772008-04-13 11:56:54 +0200164int valid_fetch_refspec(const char *refspec);
Junio C Hamano46220ca2008-03-20 23:34:37 -0700165struct refspec *parse_fetch_refspec(int nr_refspec, const char **refspec);
Daniel Barkalowd71ab172007-09-10 23:03:08 -0400166
Daniel Barkalow72ff8942009-11-18 02:42:28 +0100167void free_refspec(int nr_refspec, struct refspec *refspec);
168
Junio C Hamanoca024652013-12-03 15:41:15 -0800169extern int query_refspecs(struct refspec *specs, int nr, struct refspec *query);
Daniel Barkalow72ff8942009-11-18 02:42:28 +0100170char *apply_refspecs(struct refspec *refspecs, int nr_refspec,
171 const char *name);
172
Jeff Kingba928c12014-03-05 14:04:54 -0500173int check_push_refs(struct ref *src, int nr_refspec, const char **refspec);
Junio C Hamano29753cd2011-09-09 11:54:58 -0700174int match_push_refs(struct ref *src, struct ref **dst,
175 int nr_refspec, const char **refspec, int all);
Tay Ray Chuan20e8b462010-01-08 10:12:42 +0800176void set_ref_status_for_push(struct ref *remote_refs, int send_mirror,
177 int force_update);
Daniel Barkalow6b628162007-05-12 11:45:59 -0400178
Daniel Barkalow5d46c9d2007-05-12 11:46:03 -0400179/*
Daniel Barkalowd71ab172007-09-10 23:03:08 -0400180 * Given a list of the remote refs and the specification of things to
181 * fetch, makes a (separate) list of the refs to fetch and the local
182 * refs to store into.
183 *
184 * *tail is the pointer to the tail pointer of the list of results
185 * beforehand, and will be set to the tail pointer of the list of
186 * results afterward.
Junio C Hamano9ad7c5a2007-10-26 23:09:48 -0700187 *
188 * missing_ok is usually false, but when we are adding branch.$name.merge
189 * it is Ok if the branch is not at the remote anymore.
Daniel Barkalowd71ab172007-09-10 23:03:08 -0400190 */
Daniel Barkalow45773702007-10-29 21:05:40 -0400191int get_fetch_map(const struct ref *remote_refs, const struct refspec *refspec,
Junio C Hamano9ad7c5a2007-10-26 23:09:48 -0700192 struct ref ***tail, int missing_ok);
Daniel Barkalowd71ab172007-09-10 23:03:08 -0400193
Daniel Barkalow45773702007-10-29 21:05:40 -0400194struct ref *get_remote_ref(const struct ref *remote_refs, const char *name);
Daniel Barkalowd71ab172007-09-10 23:03:08 -0400195
196/*
Daniel Barkalow5d46c9d2007-05-12 11:46:03 -0400197 * For the given remote, reads the refspec's src and sets the other fields.
198 */
199int remote_find_tracking(struct remote *remote, struct refspec *refspec);
200
Daniel Barkalowcf818342007-09-10 23:02:56 -0400201struct branch {
202 const char *name;
203 const char *refname;
204
205 const char *remote_name;
Jeff Kingda66b272015-05-21 00:45:20 -0400206 const char *pushremote_name;
Daniel Barkalowcf818342007-09-10 23:02:56 -0400207
208 const char **merge_name;
209 struct refspec **merge;
210 int merge_nr;
Daniel Barkalow2d313472008-02-18 23:41:41 -0500211 int merge_alloc;
Jeff Kinge291c752015-05-21 00:45:36 -0400212
213 const char *push_tracking_ref;
Daniel Barkalowcf818342007-09-10 23:02:56 -0400214};
215
216struct branch *branch_get(const char *name);
Jeff Kingf0521542015-05-21 00:45:16 -0400217const char *remote_for_branch(struct branch *branch, int *explicit);
Jeff Kingda66b272015-05-21 00:45:20 -0400218const char *pushremote_for_branch(struct branch *branch, int *explicit);
Daniel Barkalowcf818342007-09-10 23:02:56 -0400219
220int branch_has_merge_config(struct branch *branch);
Shawn O. Pearce85682c12007-09-18 04:54:53 -0400221int branch_merge_matches(struct branch *, int n, const char *);
Daniel Barkalowcf818342007-09-10 23:02:56 -0400222
Jeff Kinga9f9f8c2015-05-21 00:45:28 -0400223/**
224 * Return the fully-qualified refname of the tracking branch for `branch`.
225 * I.e., what "branch@{upstream}" would give you. Returns NULL if no
226 * upstream is defined.
Jeff King3a429d02015-05-21 00:45:32 -0400227 *
228 * If `err` is not NULL and no upstream is defined, a more specific error
229 * message is recorded there (if the function does not return NULL, then
230 * `err` is not touched).
Jeff Kinga9f9f8c2015-05-21 00:45:28 -0400231 */
Jeff King3a429d02015-05-21 00:45:32 -0400232const char *branch_get_upstream(struct branch *branch, struct strbuf *err);
Jeff Kinga9f9f8c2015-05-21 00:45:28 -0400233
Jeff Kinge291c752015-05-21 00:45:36 -0400234/**
235 * Return the tracking branch that corresponds to the ref we would push to
236 * given a bare `git push` while `branch` is checked out.
237 *
238 * The return value and `err` conventions match those of `branch_get_upstream`.
239 */
240const char *branch_get_push(struct branch *branch, struct strbuf *err);
241
Andy Whitcroft28b9d6e2007-11-09 23:32:10 +0000242/* Flags to match_refs. */
243enum match_refs_flags {
244 MATCH_REFS_NONE = 0,
245 MATCH_REFS_ALL = (1 << 0),
Felipe Contreras6ddba5e2012-02-23 00:43:41 +0200246 MATCH_REFS_MIRROR = (1 << 1),
Junio C Hamanoc2aba152013-03-04 12:09:50 -0800247 MATCH_REFS_PRUNE = (1 << 2),
248 MATCH_REFS_FOLLOW_TAGS = (1 << 3)
Andy Whitcroft28b9d6e2007-11-09 23:32:10 +0000249};
250
Junio C Hamano6d21bf92008-07-02 00:51:18 -0700251/* Reporting of tracking info */
Jeff King979cb242015-05-21 20:49:11 -0400252int stat_tracking_info(struct branch *branch, int *num_ours, int *num_theirs,
253 const char **upstream_name);
Junio C Hamano6d21bf92008-07-02 00:51:18 -0700254int format_tracking_info(struct branch *branch, struct strbuf *sb);
255
Jay Soffian454e2022009-02-25 03:32:11 -0500256struct ref *get_local_heads(void);
Jay Soffian6cb4e6c2009-02-25 03:32:14 -0500257/*
Jay Soffian4229f1f2009-02-27 14:10:05 -0500258 * Find refs from a list which are likely to be pointed to by the given HEAD
259 * ref. If 'all' is false, returns the most likely ref; otherwise, returns a
260 * list of all candidate refs. If no match is found (or 'head' is NULL),
261 * returns NULL. All returns are newly allocated and should be freed.
Jay Soffian6cb4e6c2009-02-25 03:32:14 -0500262 */
Jay Soffian4229f1f2009-02-27 14:10:05 -0500263struct ref *guess_remote_head(const struct ref *head,
264 const struct ref *refs,
265 int all);
266
Jay Soffianf2ef6072009-11-10 00:03:31 -0500267/* Return refs which no longer exist on remote */
Carlos Martín Nietoed43de62011-10-15 07:04:25 +0200268struct ref *get_stale_heads(struct refspec *refs, int ref_count, struct ref *fetch_map);
Jay Soffianf2ef6072009-11-10 00:03:31 -0500269
Junio C Hamano28f5d172013-07-08 15:34:36 -0700270/*
271 * Compare-and-swap
272 */
273#define CAS_OPT_NAME "force-with-lease"
274
275struct push_cas_option {
276 unsigned use_tracking_for_rest:1;
277 struct push_cas {
278 unsigned char expect[20];
279 unsigned use_tracking:1;
280 char *refname;
281 } *entry;
282 int nr;
283 int alloc;
284};
285
286extern int parseopt_push_cas_option(const struct option *, const char *arg, int unset);
287extern int parse_push_cas_option(struct push_cas_option *, const char *arg, int unset);
Junio C Hamano28f5d172013-07-08 15:34:36 -0700288
Junio C Hamano91048a92013-07-09 11:01:06 -0700289extern int is_empty_cas(const struct push_cas_option *);
290void apply_push_cas(struct push_cas_option *, struct remote *, struct ref *);
291
Daniel Barkalow5751f492007-05-12 11:45:53 -0400292#endif