diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-08-07 02:46:16 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-08-07 02:46:16 +0000 |
commit | f6cc21874243b4d84a2db212e5c66058365bd7e7 (patch) | |
tree | edde9db07ea5ff6a3f28591302fea7caac8388f9 /src/or/routerparse.c | |
parent | f47fe829dd722b502a186b9c437cf8f57bf55405 (diff) | |
download | tor-f6cc21874243b4d84a2db212e5c66058365bd7e7.tar.gz tor-f6cc21874243b4d84a2db212e5c66058365bd7e7.zip |
Refactor ISO-style (yyyy-mm-dd hh:mm:ss) time parsing into util.c; rename format/parse_rfc1123_time; make rephist remember used bandwidth; published used bandwidth in descriptors in 15-minute chunks. Breaks unittests.
svn:r2182
Diffstat (limited to 'src/or/routerparse.c')
-rw-r--r-- | src/or/routerparse.c | 42 |
1 files changed, 3 insertions, 39 deletions
diff --git a/src/or/routerparse.c b/src/or/routerparse.c index 4995e765e6..0a4d67778d 100644 --- a/src/or/routerparse.c +++ b/src/or/routerparse.c @@ -8,10 +8,6 @@ * \brief Code to parse and validate router descriptors and directories. **/ -/* This is required on rh7 to make strptime not complain. - */ -#define _GNU_SOURCE - #include "or.h" /****************************************************************************/ @@ -164,38 +160,6 @@ int router_get_runningrouters_hash(const char *s, char *digest) "network-status","\ndirectory-signature"); } -/** Parse a date of the format "YYYY-MM-DD hh:mm:ss" and store the result into - * *<b>t</b>. - */ -/* XXX this should go in util.c, yes? -RD */ -static int parse_time(const char *cp, time_t *t) -{ - struct tm st_tm; -#ifdef HAVE_STRPTIME - if (!strptime(cp, "%Y-%m-%d %H:%M:%S", &st_tm)) { - log_fn(LOG_WARN, "Published time was unparseable"); return -1; - } -#else - unsigned int year=0, month=0, day=0, hour=100, minute=100, second=100; - if (sscanf(cp, "%u-%u-%u %u:%u:%u", &year, &month, - &day, &hour, &minute, &second) < 6) { - log_fn(LOG_WARN, "Published time was unparseable"); return -1; - } - if (year < 1970 || month < 1 || month > 12 || day < 1 || day > 31 || - hour > 23 || minute > 59 || second > 61) { - log_fn(LOG_WARN, "Published time was nonsensical"); return -1; - } - st_tm.tm_year = year; - st_tm.tm_mon = month-1; - st_tm.tm_mday = day; - st_tm.tm_hour = hour; - st_tm.tm_min = minute; - st_tm.tm_sec = second; -#endif - *t = tor_timegm(&st_tm); - return 0; -} - /** * Find the first instance of "recommended-software ...\n" at the start of * a line; return a newly allocated string containing the "..." portion. @@ -405,7 +369,7 @@ router_parse_routerlist_from_directory(const char *str, } tor_assert(tok->n_args == 1); - if (parse_time(tok->args[0], &published_on) < 0) { + if (parse_iso_time(tok->args[0], &published_on) < 0) { goto err; } @@ -517,7 +481,7 @@ router_parse_runningrouters(const char *str) goto err; } tor_assert(tok->n_args == 1); - if (parse_time(tok->args[0], &published_on) < 0) { + if (parse_iso_time(tok->args[0], &published_on) < 0) { goto err; } @@ -783,7 +747,7 @@ routerinfo_t *router_parse_entry_from_string(const char *s, log_fn(LOG_WARN, "Missing published time"); goto err; } tor_assert(tok->n_args == 1); - if (parse_time(tok->args[0], &router->published_on) < 0) + if (parse_iso_time(tok->args[0], &router->published_on) < 0) goto err; if (!(tok = find_first_by_keyword(tokens, K_ONION_KEY))) { |