[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r11985: Correct and additional fix to bug 529. (in tor/trunk: . src/or)
Author: nickm
Date: 2007-10-16 10:25:16 -0400 (Tue, 16 Oct 2007)
New Revision: 11985
Modified:
tor/trunk/
tor/trunk/src/or/networkstatus.c
Log:
r15849@catbus: nickm | 2007-10-16 10:24:38 -0400
Correct and additional fix to bug 529.
Property changes on: tor/trunk
___________________________________________________________________
svk:merge ticket from /tor/trunk [r15849] on 8246c3cf-6607-4228-993b-4d95d33730f1
Modified: tor/trunk/src/or/networkstatus.c
===================================================================
--- tor/trunk/src/or/networkstatus.c 2007-10-16 14:25:14 UTC (rev 11984)
+++ tor/trunk/src/or/networkstatus.c 2007-10-16 14:25:16 UTC (rev 11985)
@@ -1172,16 +1172,28 @@
rs = smartlist_get(ns->routerstatus_list, idx);
}
if (r>0) {
- /* We have no routerstatus for this router. Skip it. */
- router->is_named = 0;
+ /* We have no routerstatus for this router. Clear flags and skip it. */
+ if (!authdir) {
+ router->is_named = 0;
+ if (router->purpose == ROUTER_PURPOSE_GENERAL) {
+ router->is_valid = router->is_running =
+ router->is_fast = router->is_stable =
+ router->is_possible_guard = router->is_exit =
+ router->is_bad_exit = 0;
+ }
+ }
continue;
}
tor_assert(r==0);
ds = router_get_trusteddirserver_by_digest(digest);
- if (!namingdir)
- router->is_named = rs->is_named;
+ if (!namingdir) {
+ if (rs->is_named && !strcasecmp(router->nickname, rs->nickname))
+ router->is_named = 1;
+ else
+ router->is_named = 0;
+ }
if (!authdir) {
/* If we're not an authdir, believe others. */
@@ -1192,10 +1204,6 @@
router->is_possible_guard = rs->is_possible_guard;
router->is_exit = rs->is_exit;
router->is_bad_exit = rs->is_bad_exit;
- if (rs->is_named && !strcasecmp(router->nickname, rs->nickname))
- router->is_named = 1;
- else
- router->is_named = 0;
}
if (router->is_running && ds) {
download_status_reset(&ds->v2_ns_dl_status);