diff options
author | Roger Dingledine <arma@torproject.org> | 2007-02-26 05:33:17 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2007-02-26 05:33:17 +0000 |
commit | 9e44449946623a50d9f51dfcea0b765a7bdeec91 (patch) | |
tree | b634b9edef02f041103d1c1e42f9c9732ff24ab3 /src | |
parent | d40048be9bed1b333f4072fd231008e6e369ace5 (diff) | |
download | tor-9e44449946623a50d9f51dfcea0b765a7bdeec91.tar.gz tor-9e44449946623a50d9f51dfcea0b765a7bdeec91.zip |
fix a bug in our logic, but point out that maybe it's moot
svn:r9654
Diffstat (limited to 'src')
-rw-r--r-- | src/or/routerlist.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/src/or/routerlist.c b/src/or/routerlist.c index ef14d21736..67cd60de5d 100644 --- a/src/or/routerlist.c +++ b/src/or/routerlist.c @@ -1598,6 +1598,9 @@ routerlist_insert(routerlist_t *rl, routerinfo_t *ri) // routerlist_assert_ok(rl); } +/** If we're a directory cache and routerlist <b>rl</b> doesn't have + * a copy of router <b>ri</b> yet, add it to the list of old (not + * recommended but still served) descriptors. Else free it. */ static void routerlist_insert_old(routerlist_t *rl, routerinfo_t *ri) { @@ -4031,8 +4034,14 @@ update_router_descriptor_cache_downloads(time_t now) smartlist_t *dl; dl = downloadable[ns_sl_idx] = smartlist_create(); download_from[ns_sl_idx] = smartlist_create(); - if (ns->published_on + MAX_NETWORKSTATUS_AGE-10*60 > now) { + if (ns->published_on + MAX_NETWORKSTATUS_AGE+10*60 < now) { /* Don't download if the networkstatus is almost ancient. */ + /* Actually, I suspect what's happening here is that we ask + * for the descriptor when we have a given networkstatus, + * and then we get a newer networkstatus, and then we receive + * the descriptor. Having a networkstatus actually expire is + * probably a rare event, and we'll probably be happiest if + * we take this clause out. -RD */ continue; } SMARTLIST_FOREACH(ns->entries, routerstatus_t * , rs, |