/*
-** For the states FLD2, BODY2 and FMTERR2 memory is allocated for f->value.
-** For the states LENERR2, ERR2 and FILEEOF2 no memory is allocated.
+** FLD2: We read a (complete) header field
+** BODY2: We read a body line
+** LENERR2: Line is too long (>998, as defined by RFC 822)
+** FMTERR2: Header field invalid
+** IOERR2: Failure to read
+** FILEEOF2: We're at the end of the file
+**
+** f->name is only filled in FLD2.
+**
+** In FLD2, f->value contains the field's (complete) value only;
+** in BODY2, LENERR2 and FMTERR2 f->value contains the whole line;
+** in IOERR2 and FILEEOF2 f->value is not set.
*/
enum state
m_getfld2(enum state s, struct field *f, FILE *msg)
if (feof(msg)) {
return FILEEOF2;
} else {
- return ERR2;
+ return IOERR2;
}
}
+ *f->name = '\0';
+ f->namelen = 0;
+
if (nchars >= NAMESZ) {
- free(tmpline);
+ if (f->value) {
+ free(f->value);
+ }
+ f->value = tmpline;
+ f->valuelen = nchars;
return LENERR2;
}
- *f->name = '\0';
- f->namelen = 0;
-
switch (s) {
case FLD2:
if (*(tmpline + nchars - 1) != '\n') {
nchars = getline(&tmpline, &len, msg);
if (nchars <= 0) {
free(tmpline);
- return ERR2;
+ return IOERR2;
}
if (nchars >= NAMESZ) {
- free(tmpline);
+ if (f->value) {
+ free(f->value);
+ }
+ f->value = tmpline;
+ f->valuelen = nchars;
return LENERR2;
}
if (falted == FAIL) {
free(tmpline);
- return ERR2;
+ return IOERR2;
}
free(tmpline);
copyname(char *dst, char *src)
{
size_t len;
- char *sep = strchr(src, ':');
+ char *cp, *sep;
- if (!sep) {
+ if (!(sep = strchr(src, ':'))) {
return 0;
}
+ /* whitespace is forbidden in name */
+ for (cp=src; cp<sep; cp++) {
+ if (isspace(*cp)) {
+ return 0;
+ }
+ }
len = sep - src;
if (len >= NAMESZ) {