From 00fa03c8553785f9b123a8552d2b59266b418e2c Mon Sep 17 00:00:00 2001 From: "Eric S. Raymond" Date: Sat, 19 Oct 1996 13:56:30 +0000 Subject: Schwendt's correction to the sizeticker code. svn path=/trunk/; revision=350 --- driver.c | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) (limited to 'driver.c') diff --git a/driver.c b/driver.c index 8bc214aa..77e44fde 100644 --- a/driver.c +++ b/driver.c @@ -286,9 +286,22 @@ struct hostrec *queryctl; /* query control record */ headers = unixfrom = fromhdr = tohdr = cchdr = bcchdr = NULL; lines = 0; sizeticker = 0; - while (delimited || len > 0) { + while (delimited || len > 0) + { if ((n = SockGets(socket,buf,sizeof(buf))) < 0) return(PS_SOCKET); + + /* write the message size dots */ + if (n > 0) + { + sizeticker += n; + while (sizeticker >= SIZETICKER) + { + if (outlevel > O_SILENT && outlevel < O_VERBOSE) + fputc('.',stderr); + sizeticker -= SIZETICKER; + } + } len -= n; bufp = buf; if (buf[0] == '\0' || buf[0] == '\r' || buf[0] == '\n') @@ -452,18 +465,6 @@ struct hostrec *queryctl; /* query control record */ fputc('*', stderr); skipwrite:; - - /* write the message size dots */ - sizeticker += strlen(bufp); - while (sizeticker >= SIZETICKER) - { - if (outlevel > O_SILENT && outlevel < O_VERBOSE) - fputc('.',stderr); - sizeticker -= SIZETICKER; - - /* reset timeout so we don't choke on very long messages */ - alarm(queryctl->timeout); - } lines++; } -- cgit v1.2.3