diff options
author | Roger Dingledine <arma@torproject.org> | 2003-10-07 23:25:10 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2003-10-07 23:25:10 +0000 |
commit | aca4bc5126cc3b32e8f431ebd0e7d12625fb01d9 (patch) | |
tree | a65338dfdc6021703945a5c536c8deabd7705333 | |
parent | c42d928b30629af8db66078221f9ad7a4379177f (diff) | |
download | tor-aca4bc5126cc3b32e8f431ebd0e7d12625fb01d9.tar.gz tor-aca4bc5126cc3b32e8f431ebd0e7d12625fb01d9.zip |
successfully parse exit policies on future attempts too
svn:r558
-rw-r--r-- | src/or/routers.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/src/or/routers.c b/src/or/routers.c index 34f73ea254..5d3a2bb9a3 100644 --- a/src/or/routers.c +++ b/src/or/routers.c @@ -950,6 +950,7 @@ static void router_free_exit_policy(routerinfo_t *router) { void router_add_exit_policy_from_config(routerinfo_t *router) { char *s = options.ExitPolicy, *e; int last=0; + char line[1024]; if(!s) { log_fn(LOG_INFO,"No exit policy configured. Ok."); @@ -962,13 +963,16 @@ void router_add_exit_policy_from_config(routerinfo_t *router) { for(;;) { e = strchr(s,','); - if(!e) + if(!e) { last = 1; - else - *e = 0; - log_fn(LOG_DEBUG,"Adding new entry '%s'",s); - if(router_add_exit_policy_from_string(router,s) < 0) - log_fn(LOG_WARNING,"Malformed exit policy %s; skipping.", s); + strcpy(line,s); + } else { + memcpy(line,s,e-s); + line[e-s] = 0; + } + log_fn(LOG_DEBUG,"Adding new entry '%s'",line); + if(router_add_exit_policy_from_string(router,line) < 0) + log_fn(LOG_WARNING,"Malformed exit policy %s; skipping.", line); if(last) return; s = e+1; |