diff options
author | Roger Dingledine <arma@torproject.org> | 2008-12-31 14:11:46 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2008-12-31 14:11:46 +0000 |
commit | 9ea7e7f0cd33d06d64e4bae87272fce07889ff9d (patch) | |
tree | 1ca8b8d57482d463ace957f7e772014058cd1a45 /src | |
parent | 1ef472b2bd05cf210f0edc12a7cf963082e70fa3 (diff) | |
download | tor-9ea7e7f0cd33d06d64e4bae87272fce07889ff9d.tar.gz tor-9ea7e7f0cd33d06d64e4bae87272fce07889ff9d.zip |
fix a bug in download failure logging; don't do this "stop
downloading forever" thing with bridge descriptor downloads.
svn:r17833
Diffstat (limited to 'src')
-rw-r--r-- | src/or/directory.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/src/or/directory.c b/src/or/directory.c index 54a55eca06..68f438106b 100644 --- a/src/or/directory.c +++ b/src/or/directory.c @@ -3330,8 +3330,8 @@ find_dl_schedule_and_len(download_status_t *dls, int server, /** Called when an attempt to download <b>dls</b> has failed with HTTP status * <b>status_code</b>. Increment the failure count (if the code indicates a - * real failure) and set <b>dls</b>->next_attempt_at to an appropriate time in - * the future. */ + * real failure) and set <b>dls</b>-\>next_attempt_at to an appropriate time + * in the future. */ time_t download_status_increment_failure(download_status_t *dls, int status_code, const char *item, int server, time_t now) @@ -3349,7 +3349,8 @@ download_status_increment_failure(download_status_t *dls, int status_code, if (dls->n_download_failures < schedule_len) increment = schedule[dls->n_download_failures]; - else if (dls->n_download_failures == IMPOSSIBLE_TO_DOWNLOAD) + else if (dls->n_download_failures == IMPOSSIBLE_TO_DOWNLOAD && + dls->schedule != DL_SCHED_BRIDGE) increment = INT_MAX; else increment = schedule[schedule_len-1]; @@ -3360,7 +3361,7 @@ download_status_increment_failure(download_status_t *dls, int status_code, dls->next_attempt_at = TIME_MAX; if (item) { - if (dls->next_attempt_at == 0) + if (increment == 0) log_debug(LD_DIR, "%s failed %d time(s); I'll try again immediately.", item, (int)dls->n_download_failures); else if (dls->next_attempt_at < TIME_MAX) |