summaryrefslogtreecommitdiff
path: root/sideband.c
diff options
context:
space:
mode:
authorNicolas Pitre <nico@cam.org>2007-10-17 01:55:46 (GMT)
committerShawn O. Pearce <spearce@spearce.org>2007-10-17 06:54:56 (GMT)
commited1902ef5c6a30942def50809b52e41fbdcdf13f (patch)
treea3efcb9b40ad7dfd16082abff6dc7bb3cab66911 /sideband.c
parent42e18fbf5f94dd6bd303bf702e030a29fa39d6c4 (diff)
downloadgit-ed1902ef5c6a30942def50809b52e41fbdcdf13f.zip
git-ed1902ef5c6a30942def50809b52e41fbdcdf13f.tar.gz
git-ed1902ef5c6a30942def50809b52e41fbdcdf13f.tar.bz2
cope with multiple line breaks within sideband progress messages
A single sideband packet may sometimes contain multiple lines of progress messages, but we prepend "remote: " only to the whole buffer which creates a messed up display in that case. Make sure that the "remote: " prefix is applied to every remote lines. Signed-off-by: Nicolas Pitre <nico@cam.org> Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Diffstat (limited to 'sideband.c')
-rw-r--r--sideband.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/sideband.c b/sideband.c
index 277fa3c..ab8a1e9 100644
--- a/sideband.c
+++ b/sideband.c
@@ -17,7 +17,7 @@ int recv_sideband(const char *me, int in_stream, int out, int err)
strcpy(buf, "remote:");
while (1) {
int band, len;
- len = packet_read_line(in_stream, buf+7, LARGE_PACKET_MAX);
+ len = packet_read_line(in_stream, buf+7, LARGE_PACKET_MAX);
if (len == 0)
break;
if (len < 1) {
@@ -35,7 +35,22 @@ int recv_sideband(const char *me, int in_stream, int out, int err)
return SIDEBAND_REMOTE_ERROR;
case 2:
buf[7] = ' ';
- safe_write(err, buf, 8+len);
+ len += 8;
+ while (1) {
+ int brk = 8;
+ while (brk < len) {
+ brk++;
+ if (buf[brk-1] == '\n' ||
+ buf[brk-1] == '\r')
+ break;
+ }
+ safe_write(err, buf, brk);
+ if (brk < len) {
+ memmove(buf + 8, buf + brk, len - brk);
+ len = len - brk + 8;
+ } else
+ break;
+ }
continue;
case 1:
safe_write(out, buf+8, len);