freebsd-ports/mail/popper/files/patch-ai
Andrey A. Chernov 7c6b3b814b Remove wrong uidl_found increment
PR:		19038
Submitted by:	"Aaron D.Gifford" <agifford@infowest.com>
2001-02-18 10:33:54 +00:00

94 lines
3.1 KiB
Text

--- pop_dropcopy.c.orig Sun Feb 18 12:27:19 2001
+++ pop_dropcopy.c Sun Feb 18 12:29:39 2001
@@ -471,8 +471,10 @@
*cp++ = '\n';
*cp = '\0';
- mp->length += strlen("X-UIDL: ") + strlen(mp->uidl_str) + 1;
- p->drop_size += strlen("X-UIDL: ") + strlen(mp->uidl_str)+1;
+ i = strlen("X-UIDL: ") + (DIG_SIZE * 2) + 2;
+ mp->length += i;
+ p->drop_size += i;
+ mp->lines++;
/* New UIDs do not dirty the mailspool if NO_STATUS is set. They
are just recalculated each time the popper is run or LMOS is
@@ -483,9 +485,11 @@
#endif
}
- } else if (CONTENT_LENGTH && !strncmp(buffer, "Content-Length:", 15)) {
- cont_len = atoi(buffer + 15);
- MD5Update(&mdContext,(unsigned char *)buffer,strlen(buffer));
+ } else if (!strncasecmp(buffer, "Content-Length:", 15)) {
+ if (CONTENT_LENGTH) {
+ cont_len = atoi(buffer + 15);
+ MD5Update(&mdContext,(unsigned char *)buffer,strlen(buffer));
+ }
continue; /* not part of the message size */
} else if (!uidl_found && (!strncasecmp("Received:", buffer, 9) ||
!strncasecmp("Date:", buffer, 5) ||
@@ -504,8 +508,10 @@
if( (len = strlen(cp)) > MIN_UIDL_LENGTH && len < MAX_UIDL_LENGTH ) {
uidl_found++;
mp->uidl_str = (char *)strdup(cp);
- mp->length += nchar + 1;
- p->drop_size += nchar + 1;
+ len += strlen("X-UIDL: ") + 1;
+ mp->length += len;
+ p->drop_size += len;
+ mp->lines++;
}
}
continue; /* Do not include this value in the message size */
@@ -717,8 +723,10 @@
*cp++ = '\n';
*cp = '\0';
- mp->length += strlen("X-UIDL: ") + strlen(mp->uidl_str) + 1;
- p->drop_size += strlen("X-UIDL: ") + strlen(mp->uidl_str)+1;
+ i = strlen("X-UIDL: ") + (DIG_SIZE * 2) + 2;
+ mp->length += i;
+ p->drop_size += i;
+ mp->lines++;
/* New UIDs do not dirty the mailspool if NO_STATUS is set. They
are just recalculated each time the popper is run or LMOS is
@@ -729,11 +737,12 @@
#endif
}
- } else if (CONTENT_LENGTH && !strncmp(buffer, "Content-Length:", 15)) {
- cont_len = atoi(buffer + 15);
- MD5Update(&mdContext,(unsigned char *)buffer,strlen(buffer));
+ } else if (!strncasecmp(buffer, "Content-Length:", 15)) {
+ if (CONTENT_LENGTH) {
+ cont_len = atoi(buffer + 15);
+ MD5Update(&mdContext,(unsigned char *)buffer,strlen(buffer));
+ }
continue; /* Not included in message size */
-
} else if (!uidl_found && (!strncasecmp("Received:", buffer, 9) ||
!strncasecmp("Date:", buffer, 5) ||
!strncasecmp("Message-Id:",buffer, 11) ||
@@ -745,16 +754,16 @@
int len;
char *cp;
- uidl_found++;
-
/* Skip over header */
cp = &buffer[7];
while (*cp && (*cp == ' ' || *cp == '\t')) cp++;
if( (len = strlen(cp)) > MIN_UIDL_LENGTH && len < MAX_UIDL_LENGTH ) {
uidl_found++;
mp->uidl_str = (char *)strdup(cp);
- mp->length += nchar + 1;
- p->drop_size += nchar + 1;
+ len += strlen("X-UIDL: ") + 1;
+ mp->length += len;
+ p->drop_size += len;
+ mp->lines++;
}
}
continue; /* Do not include this value in the message size */