summaryrefslogtreecommitdiff
path: root/src/or/routerparse.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2004-08-07 02:46:16 +0000
committerNick Mathewson <nickm@torproject.org>2004-08-07 02:46:16 +0000
commitf6cc21874243b4d84a2db212e5c66058365bd7e7 (patch)
treeedde9db07ea5ff6a3f28591302fea7caac8388f9 /src/or/routerparse.c
parentf47fe829dd722b502a186b9c437cf8f57bf55405 (diff)
downloadtor-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.c42
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))) {