| #ifndef SEND_PACK_H |
| #define SEND_PACK_H |
| |
| #include "string-list.h" |
| |
| struct child_process; |
| struct oid_array; |
| struct ref; |
| struct repository; |
| |
| /* Possible values for push_cert field in send_pack_args. */ |
| #define SEND_PACK_PUSH_CERT_NEVER 0 |
| #define SEND_PACK_PUSH_CERT_IF_ASKED 1 |
| #define SEND_PACK_PUSH_CERT_ALWAYS 2 |
| |
| /* At least one reference has been rejected by the remote side. */ |
| #define ERROR_SEND_PACK_BAD_REF_STATUS 1 |
| |
| struct send_pack_args { |
| const char *url; |
| unsigned verbose:1, |
| quiet:1, |
| porcelain:1, |
| progress:1, |
| send_mirror:1, |
| force_update:1, |
| use_thin_pack:1, |
| use_ofs_delta:1, |
| dry_run:1, |
| /* One of the SEND_PACK_PUSH_CERT_* constants. */ |
| push_cert:2, |
| stateless_rpc:1, |
| atomic:1, |
| disable_bitmaps:1; |
| const struct string_list *push_options; |
| }; |
| |
| struct option; |
| int option_parse_push_signed(const struct option *opt, |
| const char *arg, int unset); |
| |
| /* |
| * Compute a packfile and write it to a file descriptor. The `fd` array needs |
| * to contain two file descriptors: `fd[0]` is the file descriptor used as |
| * input for the packet reader, whereas `fd[1]` is the file descriptor the |
| * packfile will be written to. |
| * |
| * Returns 0 on success, non-zero otherwise. Negative return values indicate a |
| * generic error, whereas positive return values indicate specific error |
| * conditions as documented with the `ERROR_SEND_PACK_*` constants. |
| */ |
| int send_pack(struct repository *r, struct send_pack_args *args, |
| int fd[], struct child_process *conn, |
| struct ref *remote_refs, struct oid_array *extra_have); |
| |
| #endif |