aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--NEWS6
-rw-r--r--imap.c22
2 files changed, 22 insertions, 6 deletions
diff --git a/NEWS b/NEWS
index a96eaa02..912ca74f 100644
--- a/NEWS
+++ b/NEWS
@@ -2,6 +2,12 @@
(The `lines' figures total .c, .h, .l, and .y files under version control.)
+* Updated Turkish, Danish, German, Spanish, Catalan po files.
+* Added Slovak support.
+* Configure.in update for autoconf 2.5 (Art Haas).
+* Be case-insensitive when looking for IMAP responses.
+* Fix logout-after-idle-delivery bug (Sunil Shetye).
+
fetchmail-6.1.2 (Thu Oct 31 11:41:02 EST 2002), 22135 lines:
* Jan Klaverstijn's verbosity-lowering patch.
diff --git a/imap.c b/imap.c
index 64dc4efb..d7eb0fa3 100644
--- a/imap.c
+++ b/imap.c
@@ -92,7 +92,8 @@ static int imap_ok(int sock, char *argbuf)
stage = STAGE_FETCH;
}
}
- else if (strstr(buf, "RECENT"))
+ /* a space is required to avoid confusion with the \Recent flag */
+ else if (strstr(buf, " RECENT"))
{
recentcount = atoi(buf+2);
}
@@ -133,15 +134,15 @@ static int imap_ok(int sock, char *argbuf)
while (isspace(*cp))
cp++;
- if (strncmp(cp, "OK", 2) == 0)
+ if (strncasecmp(cp, "OK", 2) == 0)
{
if (argbuf)
strcpy(argbuf, cp);
return(PS_SUCCESS);
}
- else if (strncmp(cp, "BAD", 3) == 0)
+ else if (strncasecmp(cp, "BAD", 3) == 0)
return(PS_ERROR);
- else if (strncmp(cp, "NO", 2) == 0)
+ else if (strncasecmp(cp, "NO", 2) == 0)
{
if (stage == STAGE_GETAUTH)
return(PS_AUTHFAIL); /* RFC2060, 6.2.2 */
@@ -548,6 +549,10 @@ static int imap_getrange(int sock,
* for new mail.
*/
+ /* some servers do not report RECENT after an EXPUNGE. this check
+ * forces an incorrect recentcount to be ignored. */
+ if (recentcount > count)
+ recentcount = 0;
/* this is a while loop because imap_idle() might return on other
* mailbox changes also */
while (recentcount == 0 && do_idle) {
@@ -732,15 +737,20 @@ static int imap_getsizes(int sock, int count, int *sizes)
{
unsigned int num, size;
int ok;
+ char *cp;
if ((ok = gen_recv(sock, buf, sizeof(buf))))
return(ok);
+ /* we want response matching to be case-insensitive */
+ for (cp = buf; *cp; cp++)
+ *cp = toupper(*cp);
/* an untagged NO means that a message was not readable */
- else if (strstr(buf, "* NO"))
+ if (strstr(buf, "* NO"))
;
else if (strstr(buf, "OK") || strstr(buf, "NO"))
break;
- else if (sscanf(buf, "* %u FETCH (RFC822.SIZE %u)", &num, &size) == 2) {
+ else if (sscanf(buf, "* %u FETCH (RFC822.SIZE %u)", &num, &size) == 2)
+ {
if (num > 0 && num <= count)
sizes[num - 1] = size;
else