]> git.ipfire.org Git - thirdparty/git.git/blame_incremental - send-pack.h
The eighth batch
[thirdparty/git.git] / send-pack.h
... / ...
CommitLineData
1#ifndef SEND_PACK_H
2#define SEND_PACK_H
3
4#include "string-list.h"
5
6struct child_process;
7struct oid_array;
8struct ref;
9struct repository;
10
11/* Possible values for push_cert field in send_pack_args. */
12#define SEND_PACK_PUSH_CERT_NEVER 0
13#define SEND_PACK_PUSH_CERT_IF_ASKED 1
14#define SEND_PACK_PUSH_CERT_ALWAYS 2
15
16/* At least one reference has been rejected by the remote side. */
17#define ERROR_SEND_PACK_BAD_REF_STATUS 1
18
19struct send_pack_args {
20 const char *url;
21 unsigned verbose:1,
22 quiet:1,
23 porcelain:1,
24 progress:1,
25 send_mirror:1,
26 force_update:1,
27 use_thin_pack:1,
28 use_ofs_delta:1,
29 dry_run:1,
30 /* One of the SEND_PACK_PUSH_CERT_* constants. */
31 push_cert:2,
32 stateless_rpc:1,
33 atomic:1,
34 disable_bitmaps:1;
35 const struct string_list *push_options;
36};
37
38struct option;
39int option_parse_push_signed(const struct option *opt,
40 const char *arg, int unset);
41
42/*
43 * Compute a packfile and write it to a file descriptor. The `fd` array needs
44 * to contain two file descriptors: `fd[0]` is the file descriptor used as
45 * input for the packet reader, whereas `fd[1]` is the file descriptor the
46 * packfile will be written to.
47 *
48 * Returns 0 on success, non-zero otherwise. Negative return values indicate a
49 * generic error, whereas positive return values indicate specific error
50 * conditions as documented with the `ERROR_SEND_PACK_*` constants.
51 */
52int send_pack(struct repository *r, struct send_pack_args *args,
53 int fd[], struct child_process *conn,
54 struct ref *remote_refs, struct oid_array *extra_have);
55
56#endif