aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-01-24 13:49:15 -0500
committerNick Mathewson <nickm@torproject.org>2018-01-24 13:53:56 -0500
commit92496a739aac44a537ee9062a4f0d71fba023156 (patch)
treed7f3c71ef5ad8e7c773e23b529ad64b7ca84cf02 /src
parent7792be2d446a35ad71d0c67fb762f868ae07b99c (diff)
downloadtor-92496a739aac44a537ee9062a4f0d71fba023156.tar.gz
tor-92496a739aac44a537ee9062a4f0d71fba023156.zip
Also cache the protover summary in the routerinfo_t, if we're using that
Diffstat (limited to 'src')
-rw-r--r--src/or/or.h3
-rw-r--r--src/or/routerparse.c21
2 files changed, 19 insertions, 5 deletions
diff --git a/src/or/or.h b/src/or/or.h
index 0be19fdbdd..2ef27a99a0 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -2299,6 +2299,9 @@ typedef struct {
* this routerinfo. Used only during voting. */
unsigned int omit_from_vote:1;
+ /** Flags to summarize the protocol versions for this routerinfo_t. */
+ protover_summary_flags_t pv;
+
/** Tor can use this router for general positions in circuits; we got it
* from a directory server as usual, or we're an authority and a server
* uploaded it. */
diff --git a/src/or/routerparse.c b/src/or/routerparse.c
index 1cbbb17283..54759c9a7b 100644
--- a/src/or/routerparse.c
+++ b/src/or/routerparse.c
@@ -379,6 +379,10 @@ static int check_signature_token(const char *digest,
int flags,
const char *doctype);
+static void summarize_protover_flags(protover_summary_flags_t *out,
+ const char *protocols,
+ const char *version);
+
#undef DEBUG_AREA_ALLOC
#ifdef DEBUG_AREA_ALLOC
@@ -1895,12 +1899,19 @@ router_parse_entry_from_string(const char *s, const char *end,
}
}
- if ((tok = find_opt_by_keyword(tokens, K_PLATFORM))) {
- router->platform = tor_strdup(tok->args[0]);
- }
+ {
+ const char *version = NULL, *protocols = NULL;
+ if ((tok = find_opt_by_keyword(tokens, K_PLATFORM))) {
+ router->platform = tor_strdup(tok->args[0]);
+ version = tok->args[0];
+ }
+
+ if ((tok = find_opt_by_keyword(tokens, K_PROTO))) {
+ router->protocol_list = tor_strdup(tok->args[0]);
+ protocols = tok->args[0];
+ }
- if ((tok = find_opt_by_keyword(tokens, K_PROTO))) {
- router->protocol_list = tor_strdup(tok->args[0]);
+ summarize_protover_flags(&router->pv, protocols, version);
}
if ((tok = find_opt_by_keyword(tokens, K_CONTACT))) {