aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric S. Raymond <esr@thyrsus.com>1996-09-19 06:02:28 +0000
committerEric S. Raymond <esr@thyrsus.com>1996-09-19 06:02:28 +0000
commit8cb6a03929d5938918e5f04a805ef7fc3feb9241 (patch)
tree23117baddb1a69bf6c211f18d2cb78ca8af07eb2
parent2e3b3361491deec452b2b44bf8cd2c1fc880af55 (diff)
downloadfetchmail-8cb6a03929d5938918e5f04a805ef7fc3feb9241.tar.gz
fetchmail-8cb6a03929d5938918e5f04a805ef7fc3feb9241.tar.bz2
fetchmail-8cb6a03929d5938918e5f04a805ef7fc3feb9241.zip
Added improved sizeticker code.
svn path=/trunk/; revision=99
-rw-r--r--NEWS2
-rw-r--r--driver.c12
2 files changed, 8 insertions, 6 deletions
diff --git a/NEWS b/NEWS
index 05432611..f9ab2387 100644
--- a/NEWS
+++ b/NEWS
@@ -55,6 +55,8 @@ driver to SMTP. (This requires that we find a POP2 server to test with.)
* Ported to QNX (see the Makefile).
+* Add Michael Scwendt's code for improved sizeticker.
+
* Warn users that running concurrent instances of popclient is a bad idea.
3.1:
diff --git a/driver.c b/driver.c
index 86bd3e93..a2bb8239 100644
--- a/driver.c
+++ b/driver.c
@@ -554,14 +554,14 @@ int rewrite;
fprintf(stderr,"reading message %d",++msgnum);
/* won't do the '...' if retrieved messages are being sent to stdout */
if (mboxfd == 1)
- fputs(".\n",stderr);
+ fputs("\n",stderr);
}
/* read the message content from the server */
inheaders = 1;
headers = unixfrom = fromhdr = tohdr = cchdr = bcchdr = NULL;
lines = 0;
- sizeticker = MSGBUFSIZE;
+ sizeticker = 0;
while (delimited || len > 0) {
if ((n = SockGets(socket,buf,sizeof(buf))) < 0)
return(PS_SOCKET);
@@ -710,12 +710,12 @@ int rewrite;
skipwrite:;
- sizeticker -= strlen(bufp);
- if (sizeticker <= 0)
+ sizeticker += strlen(bufp);
+ while (sizeticker >= MSGBUFSIZE)
{
if (outlevel > O_SILENT && outlevel < O_VERBOSE && mboxfd != 1)
fputc('.',stderr);
- sizeticker = MSGBUFSIZE;
+ sizeticker -= MSGBUFSIZE;
}
lines++;
}
@@ -756,7 +756,7 @@ int rewrite;
if (outlevel == O_VERBOSE)
fprintf(stderr,"(%d lines of message content)\n",lines);
else if (outlevel > O_SILENT && mboxfd != 1)
- fputs(".\n",stderr);
+ fputs("\n",stderr);
else
;
return(0);