From: Nick Mathewson Date: Fri, 5 Sep 2008 20:04:27 +0000 (+0000) Subject: It is probably some kind of misdeed to say for (i=0;i<2;++i) { A=i?x:y; foo(bar(A... X-Git-Tag: tor-0.2.1.6-alpha~83 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a56a072f296627eba190e83f96f5ca087358a14b;p=thirdparty%2Ftor.git It is probably some kind of misdeed to say for (i=0;i<2;++i) { A=i?x:y; foo(bar(A)); } rather than foo(bar(x)); foo(bar(y)); . Also, it can confuse tools. svn:r16777 --- diff --git a/src/or/dirvote.c b/src/or/dirvote.c index 661ebc1813..c036576fb8 100644 --- a/src/or/dirvote.c +++ b/src/or/dirvote.c @@ -455,6 +455,23 @@ consensus_method_is_supported(int method) return (method >= 1) && (method <= 5); } +/** Helper: given lst, a list of version strings such that every + * version appears once for every versioning voter who recommends it, returna + * newly allocated string holding the resulting client-versions or + * server-versions list. May change contents of lst */ +static char * +compute_consensus_versions_list(smartlist_t *lst, int n_versioning) +{ + int min = n_versioning / 2; + smartlist_t *good = smartlist_create(); + char *result; + sort_version_list(lst, 0); + get_frequent_members(good, lst, min); + result = smartlist_join_strings(good, ",", 0, NULL); + smartlist_free(good); + return result; +} + /** Given a list of vote networkstatus_t in votes, our public * authority identity_key, our private authority signing_key, * and the number of total_authorities that we believe exist in our @@ -510,7 +527,7 @@ networkstatus_compute_consensus(smartlist_t *votes, int n_versioning_clients = 0, n_versioning_servers = 0; smartlist_t *combined_client_versions = smartlist_create(); smartlist_t *combined_server_versions = smartlist_create(); - int j; + SMARTLIST_FOREACH(votes, networkstatus_t *, v, { tor_assert(v->type == NS_TYPE_VOTE); @@ -551,23 +568,15 @@ networkstatus_compute_consensus(smartlist_t *votes, tor_assert(vote_seconds >= MIN_VOTE_SECONDS); tor_assert(dist_seconds >= MIN_DIST_SECONDS); - for (j = 0; j < 2; ++j) { - smartlist_t *lst = - j ? combined_server_versions : combined_client_versions; - int min = (j ? n_versioning_servers : n_versioning_clients) / 2; - smartlist_t *good = smartlist_create(); - char *res; - sort_version_list(lst, 0); - get_frequent_members(good, lst, min); - res = smartlist_join_strings(good, ",", 0, NULL); - if (j) - server_versions = res; - else - client_versions = res; - SMARTLIST_FOREACH(lst, char *, cp, tor_free(cp)); - smartlist_free(good); - smartlist_free(lst); - } + server_versions = compute_consensus_versions_list(combined_server_versions, + n_versioning_servers); + client_versions = compute_consensus_versions_list(combined_client_versions, + n_versioning_clients); + + SMARTLIST_FOREACH(combined_server_versions, char *, cp, tor_free(cp)); + SMARTLIST_FOREACH(combined_client_versions, char *, cp, tor_free(cp)); + smartlist_free(combined_server_versions); + smartlist_free(combined_client_versions); smartlist_sort_strings(flags); smartlist_uniq_strings(flags);