blob: 5a25331be55d30dbc6b4d777da3cf015118dcf3d [file] [log] [blame]
Junio C Hamano49a52b12006-09-10 01:06:33 -07001#ifndef SIDEBAND_H
2#define SIDEBAND_H
3
Jonathan Tanfbd76cd2019-01-16 11:28:13 -08004enum sideband_type {
5 SIDEBAND_PROTOCOL_ERROR = -2,
6 SIDEBAND_REMOTE_ERROR = -1,
7 SIDEBAND_FLUSH = 0,
8 SIDEBAND_PRIMARY = 1
9};
Junio C Hamano49a52b12006-09-10 01:06:33 -070010
Jonathan Tanfbd76cd2019-01-16 11:28:13 -080011/*
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.
15 *
16 * If this packet is SIDEBAND_PROTOCOL_ERROR, SIDEBAND_REMOTE_ERROR, or a
17 * progress packet, also prints a message to stderr.
18 *
19 * scratch must be a struct strbuf allocated by the caller. It is used to store
20 * progress messages split across multiple packets.
Jeff Kingaf22a632020-10-28 05:33:24 -040021 *
22 * The "status" parameter is a pkt-line response as returned by
23 * packet_read_with_status() (e.g., PACKET_READ_NORMAL).
Jonathan Tanfbd76cd2019-01-16 11:28:13 -080024 */
Jeff Kingaf22a632020-10-28 05:33:24 -040025int demultiplex_sideband(const char *me, int status,
26 char *buf, int len,
Jonathan Tan0bbc0bc2019-01-16 11:28:14 -080027 int die_on_error,
Jonathan Tanfbd76cd2019-01-16 11:28:13 -080028 struct strbuf *scratch,
29 enum sideband_type *sideband_type);
30
Lukas Fleischer4c4b7d12016-06-14 16:49:16 +020031void send_sideband(int fd, int band, const char *data, ssize_t sz, int packet_max);
Junio C Hamano49a52b12006-09-10 01:06:33 -070032
33#endif