X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=lib-mime%2Frfc822parse.c;h=a1b4d54324a35b7984b9f8fb32a83d92538e4c85;hp=d2fb218af4e03a2a5ef84aa26f90717732770965;hb=819c071fa7efc8dffb4dd92f36f0111227ff692f;hpb=e0571c496935f226abe4a22921b5b4e10d1481e8 diff --git a/lib-mime/rfc822parse.c b/lib-mime/rfc822parse.c index d2fb218..a1b4d54 100644 --- a/lib-mime/rfc822parse.c +++ b/lib-mime/rfc822parse.c @@ -592,11 +592,22 @@ time_t mutt_parse_date(const char *s, HEADER *h) { struct tm tm; const char *loc; + time_t tz; + + loc = setlocale(LC_ALL, "C"); p_clear(&tm, 1); - loc = setlocale(LC_TIME, "C"); - s = strptime(s, "%a, %d %b %Y %T %z", &tm); - setlocale(LC_TIME, loc); - return mutt_mktime(&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_ALL, ""); + return 0; + + ok: + 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, @@ -659,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 @@ -739,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); @@ -815,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) { @@ -1049,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 [ ]