receive-pack: Wrap status reports inside side-band-64k

If the client requests the side-band-64k protocol capability we
now wrap the status report data inside of packets sent to band #1.
This permits us to later send additional progress or informational
messages down band #2.

If side-band-64k was enabled, we always send a final flush packet
to let the client know we are done transmitting.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Shawn O. Pearce 2010-02-05 12:57:41 -08:00 committed by Junio C Hamano
parent 185c04e041
commit 38a81b4e82

View File

@ -2,6 +2,7 @@
#include "pack.h" #include "pack.h"
#include "refs.h" #include "refs.h"
#include "pkt-line.h" #include "pkt-line.h"
#include "sideband.h"
#include "run-command.h" #include "run-command.h"
#include "exec_cmd.h" #include "exec_cmd.h"
#include "commit.h" #include "commit.h"
@ -27,6 +28,7 @@ static int receive_unpack_limit = -1;
static int transfer_unpack_limit = -1; static int transfer_unpack_limit = -1;
static int unpack_limit = 100; static int unpack_limit = 100;
static int report_status; static int report_status;
static int use_sideband;
static int prefer_ofs_delta = 1; static int prefer_ofs_delta = 1;
static int auto_update_server_info; static int auto_update_server_info;
static int auto_gc = 1; static int auto_gc = 1;
@ -110,7 +112,7 @@ static int show_ref(const char *path, const unsigned char *sha1, int flag, void
else else
packet_write(1, "%s %s%c%s%s\n", packet_write(1, "%s %s%c%s%s\n",
sha1_to_hex(sha1), path, 0, sha1_to_hex(sha1), path, 0,
" report-status delete-refs", " report-status delete-refs side-band-64k",
prefer_ofs_delta ? " ofs-delta" : ""); prefer_ofs_delta ? " ofs-delta" : "");
sent_capabilities = 1; sent_capabilities = 1;
return 0; return 0;
@ -466,6 +468,8 @@ static void read_head_info(void)
if (reflen + 82 < len) { if (reflen + 82 < len) {
if (strstr(refname + reflen + 1, "report-status")) if (strstr(refname + reflen + 1, "report-status"))
report_status = 1; report_status = 1;
if (strstr(refname + reflen + 1, "side-band-64k"))
use_sideband = LARGE_PACKET_MAX;
} }
cmd = xmalloc(sizeof(struct command) + len - 80); cmd = xmalloc(sizeof(struct command) + len - 80);
hashcpy(cmd->old_sha1, old_sha1); hashcpy(cmd->old_sha1, old_sha1);
@ -565,17 +569,25 @@ static const char *unpack(void)
static void report(const char *unpack_status) static void report(const char *unpack_status)
{ {
struct command *cmd; struct command *cmd;
packet_write(1, "unpack %s\n", struct strbuf buf = STRBUF_INIT;
unpack_status ? unpack_status : "ok");
packet_buf_write(&buf, "unpack %s\n",
unpack_status ? unpack_status : "ok");
for (cmd = commands; cmd; cmd = cmd->next) { for (cmd = commands; cmd; cmd = cmd->next) {
if (!cmd->error_string) if (!cmd->error_string)
packet_write(1, "ok %s\n", packet_buf_write(&buf, "ok %s\n",
cmd->ref_name); cmd->ref_name);
else else
packet_write(1, "ng %s %s\n", packet_buf_write(&buf, "ng %s %s\n",
cmd->ref_name, cmd->error_string); cmd->ref_name, cmd->error_string);
} }
packet_flush(1); packet_buf_flush(&buf);
if (use_sideband)
send_sideband(1, 1, buf.buf, buf.len, use_sideband);
else
safe_write(1, buf.buf, buf.len);
strbuf_release(&buf);
} }
static int delete_only(struct command *cmd) static int delete_only(struct command *cmd)
@ -705,5 +717,7 @@ int cmd_receive_pack(int argc, const char **argv, const char *prefix)
if (auto_update_server_info) if (auto_update_server_info)
update_server_info(0); update_server_info(0);
} }
if (use_sideband)
packet_flush(1);
return 0; return 0;
} }