copy.c
editmsg.c
flags.c
- from.c
handler.c
headers.c
help.c
+++ /dev/null
-/*
- * Copyright notice from original mutt:
- * Copyright (C) 1996-2000 Michael R. Elkins <me@mutt.org>
- *
- * This file is part of mutt-ng, see http://www.muttng.org/.
- * It's licensed under the GNU General Public License,
- * please see the file GPL in the top level source directory.
- */
-
-#include <lib-lib/lib-lib.h>
-
-#include "mutt.h"
-
-int mutt_check_month (const char *s)
-{
- int i;
-
- for (i = 0; i < 12; i++)
- if (m_strncasecmp(s, Months[i], 3) == 0)
- return (i);
- return (-1); /* error */
-}
-
-static int is_day_name (const char *s)
-{
- int i;
-
- if ((m_strlen(s) < 3) || !*(s + 3) || !ISSPACE (*(s + 3)))
- return 0;
- for (i = 0; i < 7; i++)
- if (m_strncasecmp(s, Weekdays[i], 3) == 0)
- return 1;
- return 0;
-}
-
-/*
- * A valid message separator looks like:
- *
- * From [ <return-path> ] <weekday> <month> <day> <time> [ <timezone> ] <year>
- */
-
-int is_from (const char *s, char *path, ssize_t pathlen, time_t * tp)
-{
- struct tm tm;
- int yr;
-
- if (path)
- *path = 0;
-
- if (m_strncmp("From ", s, 5) != 0)
- return 0;
-
- s = m_strnextsp(s); /* skip over the From part. */
- s = skipspaces(s);
- if (!*s)
- return 0;
-
- if (!is_day_name (s)) {
- const char *p;
- ssize_t len;
- short q = 0;
-
- for (p = s; *p && (q || !ISSPACE (*p)); p++) {
- if (*p == '\\') {
- if (*++p == '\0')
- return 0;
- }
- else if (*p == '"') {
- q = !q;
- }
- }
-
- if (q || !*p)
- return 0;
-
- if (path) {
- len = p - s;
- if (len + 1 > pathlen)
- len = pathlen - 1;
- memcpy (path, s, len);
- path[len] = 0;
- }
-
- s = vskipspaces(p + 1);
- if (!*s)
- return 0;
-
- if (!is_day_name (s)) {
- return 0;
- }
- }
-
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
-
- /* do a quick check to make sure that this isn't really the day of the week.
- * this could happen when receiving mail from a local user whose login name
- * is the same as a three-letter abbreviation of the day of the week.
- */
- if (is_day_name (s)) {
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
- }
-
- /* now we should be on the month. */
- if ((tm.tm_mon = mutt_check_month (s)) < 0)
- return 0;
-
- /* day */
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
- if (sscanf (s, "%d", &tm.tm_mday) != 1)
- return 0;
-
- /* time */
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
-
- /* Accept either HH:MM or HH:MM:SS */
- if (sscanf (s, "%d:%d:%d", &tm.tm_hour, &tm.tm_min, &tm.tm_sec) == 3);
- else if (sscanf (s, "%d:%d", &tm.tm_hour, &tm.tm_min) == 2)
- tm.tm_sec = 0;
- else
- return 0;
-
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
-
- /* timezone? */
- if (isalpha ((unsigned char) *s) || *s == '+' || *s == '-') {
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
-
- /*
- * some places have two timezone fields after the time, e.g.
- * From xxxx@yyyyyyy.fr Wed Aug 2 00:39:12 MET DST 1995
- */
- if (isalpha ((unsigned char) *s)) {
- s = m_strnextsp(s);
- s = skipspaces(s);
- if (!*s)
- return 0;
- }
- }
-
- /* year */
- if (sscanf (s, "%d", &yr) != 1)
- return 0;
- tm.tm_year = yr > 1900 ? yr - 1900 : (yr < 70 ? yr + 100 : yr);
-
- tm.tm_isdst = -1;
-
- if (tp)
- *tp = mutt_mktime (&tm, 0);
- return 1;
-}
WHERE char *SmimeCryptAlg;
#ifdef MAIN_C
-const char *Weekdays[] = { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
const char *Months[] =
{ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct",
"Nov", "Dec", "ERR" };
#else
-extern const char *Weekdays[];
extern const char *Months[];
#endif
{
struct tm tm;
const char *loc;
- time_t tz;
p_clear(&tm, 1);
loc = setlocale(LC_TIME, "C");
extern const char RFC822Specials[];
+bool is_from(const char *, char *, ssize_t, time_t*);
ssize_t mutt_read_rfc822_line(FILE*, char**, ssize_t*);
string_list_t *mutt_parse_references(char *, int);
int mutt_check_encoding(const char *);
hdr->attach_valid = 1;
return hdr->attach_total;
}
+
+/*
+ * A valid message separator looks like:
+ *
+ * From [ <return-path> ] <weekday> <month> <day> <time> [ <timezone> ] <year>
+ */
+bool is_from(const char *s, char *path, ssize_t pathlen, time_t *tp)
+{
+ const char *p;
+ struct tm tm;
+ char *loc;
+ int q = 0;
+
+ if (path)
+ *path = 0;
+
+ if (m_strncmp("From ", s, 5) != 0)
+ return false;
+
+ s = skipspaces(s + 5); /* skip over the From part. */
+ if (!*s)
+ return false;
+
+ for (p = s; *p && (q || !ISSPACE(*p)); p++) {
+ if (*p == '\\') {
+ if (*++p == '\0')
+ return false;
+ }
+ else if (*p == '"') {
+ q = !q;
+ }
+ }
+
+ if (q || !*p)
+ return false;
+
+ if (path)
+ m_strncpy(path, pathlen, s, p - s);
+
+ s = vskipspaces(p + 1);
+ if (!*s)
+ return false;
+
+ loc = setlocale(LC_TIME, "C");
+ for (int i = 0; i < 4; i++) {
+ static char const * const formats[] = {
+ "%a %b %d %H:%M:%S %Y",
+ "%a %b %d %H:%M:%S %z %Y",
+ "%a %b %d %H:%M %Y",
+ "%a %b %d %H:%M %z %Y",
+ };
+
+ p_clear(&tm, 1);
+ p = strptime(s, formats[i], &tm);
+ if (p) {
+ s = p;
+ goto ok;
+ }
+ }
+ setlocale(LC_TIME, loc);
+ return false;
+
+ ok:
+ if (tp)
+ *tp = mutt_mktime(&tm, 1);
+ return true;
+}
int mutt_cmp_header (const HEADER*, const HEADER*);
-int is_from (const char *, char *, ssize_t, time_t *);
-
ssize_t _mutt_expand_path(char *, ssize_t, const char *, int);
#define mutt_expand_path(s, n) _mutt_expand_path((s), (n), (s), 0)