merge-ort/merge-recursive: do report errors in `merge_submodule()`
[git/gitster.git] / sideband.h
blob5a25331be55d30dbc6b4d777da3cf015118dcf3d
1 #ifndef SIDEBAND_H
2 #define SIDEBAND_H
4 enum sideband_type {
5 SIDEBAND_PROTOCOL_ERROR = -2,
6 SIDEBAND_REMOTE_ERROR = -1,
7 SIDEBAND_FLUSH = 0,
8 SIDEBAND_PRIMARY = 1
9 };
12 * Inspects a multiplexed packet read from the remote. If this packet is a
13 * progress packet and thus should not be processed by the caller, returns 0.
14 * Otherwise, returns 1, releases scratch, and sets sideband_type.
16 * If this packet is SIDEBAND_PROTOCOL_ERROR, SIDEBAND_REMOTE_ERROR, or a
17 * progress packet, also prints a message to stderr.
19 * scratch must be a struct strbuf allocated by the caller. It is used to store
20 * progress messages split across multiple packets.
22 * The "status" parameter is a pkt-line response as returned by
23 * packet_read_with_status() (e.g., PACKET_READ_NORMAL).
25 int demultiplex_sideband(const char *me, int status,
26 char *buf, int len,
27 int die_on_error,
28 struct strbuf *scratch,
29 enum sideband_type *sideband_type);
31 void send_sideband(int fd, int band, const char *data, ssize_t sz, int packet_max);
33 #endif