X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=lib-mime%2Frfc822parse.c;h=49e806d7dfc456d65da1afc040a85a9915fdbfed;hp=d5614fc56cf26505fc56ea5df5e8987378829b0f;hb=049b21f53af51ad7259613f5eefaa0f37b1b2167;hpb=ee48d4232053aee30adb5afb48b147e31d7aedfa diff --git a/lib-mime/rfc822parse.c b/lib-mime/rfc822parse.c index d5614fc..49e806d 100644 --- a/lib-mime/rfc822parse.c +++ b/lib-mime/rfc822parse.c @@ -419,7 +419,7 @@ BODY *mutt_read_mime_header(FILE *fp, int digest) } p_delete(&line); - return (body); + return body; } void mutt_parse_part(FILE *fp, BODY *b) @@ -578,7 +578,7 @@ mutt_parse_multipart(FILE *fp, const char *bound, off_t end_off, int digest) mutt_parse_part(fp, b); } - return (head); + return head; } /* parses a date string in RFC822 format: @@ -592,20 +592,22 @@ time_t mutt_parse_date(const char *s, HEADER *h) { struct tm tm; const char *loc; - loc = setlocale(LC_TIME, "C"); + time_t tz; + loc = setlocale(LC_ALL, "C"); p_clear(&tm, 1); if (strptime(s, "%a, %d %b %Y %H:%M:%S %z", &tm)) goto ok; p_clear(&tm, 1); if (strptime(s, "%a, %d %b %Y %H:%M %z", &tm)) goto ok; - setlocale(LC_TIME, loc); + setlocale(LC_ALL, ""); return 0; ok: - setlocale(LC_TIME, loc); - return mutt_mktime(&tm, 1); + setlocale(LC_ALL, ""); + tz = tm.tm_gmtoff; + return timegm(&tm) - tz; } string_list_t **mutt_parse_rfc822_line(ENVELOPE *e, HEADER *hdr, char *line, char *p, @@ -668,15 +670,6 @@ string_list_t **mutt_parse_rfc822_line(ENVELOPE *e, HEADER *hdr, char *line, cha hdr->expired = 1; break; -#ifdef USE_NNTP - case MIME_FOLLOWUP_TO: - if (!e->followup_to) { - m_strrtrim(p); - e->followup_to = m_strdup(skipspaces(p)); - } - break; -#endif - case MIME_FROM: e->from = rfc822_parse_adrlist(e->from, p); /* don't leave from info NULL if there's an invalid address (or @@ -748,14 +741,6 @@ string_list_t **mutt_parse_rfc822_line(ENVELOPE *e, HEADER *hdr, char *line, cha hdr->mime = 1; break; -#ifdef USE_NNTP - case MIME_NEWSGROUPS: - p_delete(&e->newsgroups); - m_strrtrim(p); - e->newsgroups = m_strdup(skipspaces(p)); - break; -#endif - case MIME_ORGANIZATION: if (!e->organization && mime_which_token(p, -1) == MIME_UNKNOWN) e->organization = m_strdup(p); @@ -824,13 +809,6 @@ string_list_t **mutt_parse_rfc822_line(ENVELOPE *e, HEADER *hdr, char *line, cha e->x_label = m_strdup(p); break; -#ifdef USE_NNTP - case MIME_XREF: - if (!e->xref) - e->xref = m_strdup(p); - break; -#endif - case MIME_X_STATUS: if (hdr) { while (*p) { @@ -1058,3 +1036,72 @@ int mutt_count_body_parts(HEADER *hdr, int flags) hdr->attach_valid = 1; return hdr->attach_total; } + +/* + * A valid message separator looks like: + * + * From [ ]