diff options
author | Nick Mathewson <nickm@torproject.org> | 2011-05-03 17:30:58 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2011-05-03 17:30:58 -0400 |
commit | 599d1b62b4c98ad5fea1d0f3f5523c8dc53779e1 (patch) | |
tree | 2031716952ee01ba2fbec4f325606def7c2dcaab /src/or | |
parent | 865d53be5484ef06ca4a5103d9ebca343e19f7d4 (diff) | |
parent | 68ae5afa5a172fbc485eda7e6bfd4750fa6a69f5 (diff) | |
download | tor-599d1b62b4c98ad5fea1d0f3f5523c8dc53779e1.tar.gz tor-599d1b62b4c98ad5fea1d0f3f5523c8dc53779e1.zip |
Merge remote-tracking branch 'origin/maint-0.2.2'
Conflicts:
src/or/main.c
src/or/microdesc.c
Diffstat (limited to 'src/or')
-rw-r--r-- | src/or/main.c | 1 | ||||
-rw-r--r-- | src/or/microdesc.c | 11 |
2 files changed, 9 insertions, 3 deletions
diff --git a/src/or/main.c b/src/or/main.c index 7a97a21b26..a50a3cd16d 100644 --- a/src/or/main.c +++ b/src/or/main.c @@ -1269,6 +1269,7 @@ run_scheduled_events(time_t now) rep_history_clean(now - options->RephistTrackTime); rend_cache_clean(now); rend_cache_clean_v2_descs_as_dir(now); + microdesc_cache_rebuild(NULL, 0); #define CLEAN_CACHES_INTERVAL (30*60) time_to_clean_caches = now + CLEAN_CACHES_INTERVAL; } diff --git a/src/or/microdesc.c b/src/or/microdesc.c index 5d3f1c372a..6209bbf33e 100644 --- a/src/or/microdesc.c +++ b/src/or/microdesc.c @@ -245,8 +245,6 @@ microdescs_add_list_to_cache(microdesc_cache_t *cache, if (f) finish_writing_to_file(open_file); /*XXX Check me.*/ - microdesc_cache_rebuild(cache, 0/* only as needed */); - { networkstatus_t *ns = networkstatus_get_latest_consensus(); if (ns && ns->flavor == FLAV_MICRODESC) @@ -273,6 +271,7 @@ microdesc_cache_clear(microdesc_cache_t *cache) } cache->total_len_seen = 0; cache->n_seen = 0; + cache->bytes_dropped = 0; } /** Reload the contents of <b>cache</b> from disk. If it is empty, load it @@ -314,7 +313,7 @@ microdesc_cache_reload(microdesc_cache_t *cache) log_notice(LD_DIR, "Reloaded microdescriptor cache. Found %d descriptors.", total); - microdesc_cache_clean(cache, 0, 0); + microdesc_cache_rebuild(cache, 0 /* don't force */); return 0; } @@ -399,6 +398,12 @@ microdesc_cache_rebuild(microdesc_cache_t *cache, int force) off_t off = 0; int orig_size, new_size; + if (cache == NULL) { + cache = the_microdesc_cache; + if (cache == NULL) + return 0; + } + /* Remove dead descriptors */ microdesc_cache_clean(cache, 0/*cutoff*/, 0/*force*/); |