added support for SOCKS5 proxies in client_test and fixed an assert when using proxies

This commit is contained in:
Arvid Norberg 2010-07-03 06:56:09 +00:00
parent 70ea511409
commit 92593abf89
2 changed files with 28 additions and 1 deletions

View File

@ -768,6 +768,7 @@ int main(int argc, char* argv[])
" -A <num pieces> allowed pieces set size\n" " -A <num pieces> allowed pieces set size\n"
" -R <num blocks> number of blocks per read cache line\n" " -R <num blocks> number of blocks per read cache line\n"
" -O Disallow disk job reordering\n" " -O Disallow disk job reordering\n"
" -P <host:port> Use the specified SOCKS5 proxy\n"
" -H Don't start DHT\n" " -H Don't start DHT\n"
" " " "
"\n\n" "\n\n"
@ -930,6 +931,31 @@ int main(int argc, char* argv[])
case 'A': settings.allowed_fast_set_size = atoi(arg); break; case 'A': settings.allowed_fast_set_size = atoi(arg); break;
case 'R': settings.read_cache_line_size = atoi(arg); break; case 'R': settings.read_cache_line_size = atoi(arg); break;
case 'O': settings.allow_reordered_disk_operations = false; --i; break; case 'O': settings.allow_reordered_disk_operations = false; --i; break;
case 'P':
{
char* port = strchr(arg, ':');
if (port == 0)
{
fprintf(stderr, "invalid proxy hostname, no port found\n");
break;
}
*port++ = 0;
proxy_settings ps;
ps.hostname = arg;
ps.port = atoi(port);
if (ps.port == 0) {
fprintf(stderr, "invalid proxy port\n");
break;
}
ps.type = proxy_settings::socks5;
ses.set_peer_proxy(ps);
ses.set_web_seed_proxy(ps);
ses.set_tracker_proxy(ps);
#ifndef TORRENT_DISABLE_DHT
ses.set_dht_proxy(ps);
#endif
}
break;
} }
++i; // skip the argument ++i; // skip the argument
} }

View File

@ -165,8 +165,9 @@ public:
} }
#endif #endif
endpoint_type remote_endpoint(error_code& /*ec*/) const endpoint_type remote_endpoint(error_code& ec) const
{ {
if (!m_sock.is_open()) ec = asio::error::not_connected;
return m_remote_endpoint; return m_remote_endpoint;
} }