fixes in connection policy. fixes #29. inserted more invariant checks in policy

This commit is contained in:
Arvid Norberg 2007-04-13 17:47:40 +00:00
parent b08037d094
commit 3d759e8936
3 changed files with 35 additions and 29 deletions

View File

@ -208,22 +208,6 @@ namespace libtorrent
iterator find_disconnect_candidate(); iterator find_disconnect_candidate();
iterator find_connect_candidate(); iterator find_connect_candidate();
// a functor that identifies peers that have disconnected and that
// are too old for still being saved.
struct old_disconnected_peer
{
bool operator()(const peer& p)
{
ptime not_tried_yet(min_time());
// this timeout has to be customizable!
return p.connection == 0
&& p.connected != not_tried_yet
&& time_now() - p.connected > minutes(120);
}
};
std::list<peer> m_peers; std::list<peer> m_peers;
torrent* m_torrent; torrent* m_torrent;

View File

@ -233,13 +233,8 @@ namespace libtorrent
else else
t->get_policy().peer_is_interesting(*this); t->get_policy().peer_is_interesting(*this);
} }
catch (std::exception& e) // may throw an asio error if socket has disconnected
{ catch (std::exception& e) {}
#ifndef NDEBUG
std::cerr << e.what() << std::endl;
assert(false);
#endif
}
assert(is_interesting() == interested); assert(is_interesting() == interested);
} }

View File

@ -462,6 +462,8 @@ namespace libtorrent
policy::iterator policy::find_disconnect_candidate() policy::iterator policy::find_disconnect_candidate()
{ {
INVARIANT_CHECK;
iterator disconnect_peer = m_peers.end(); iterator disconnect_peer = m_peers.end();
double slowest_transfer_rate = std::numeric_limits<double>::max(); double slowest_transfer_rate = std::numeric_limits<double>::max();
@ -491,7 +493,11 @@ namespace libtorrent
double transfer_rate double transfer_rate
= transferred_amount / (connected_time_in_seconds + 1); = transferred_amount / (connected_time_in_seconds + 1);
if (transfer_rate <= slowest_transfer_rate) // prefer to disconnect uninteresting peers, and secondly slow peers
if (transfer_rate <= slowest_transfer_rate
|| (disconnect_peer != m_peers.end()
&& disconnect_peer->connection->is_interesting()
&& !c->is_interesting()))
{ {
slowest_transfer_rate = transfer_rate; slowest_transfer_rate = transfer_rate;
disconnect_peer = i; disconnect_peer = i;
@ -502,6 +508,8 @@ namespace libtorrent
policy::iterator policy::find_connect_candidate() policy::iterator policy::find_connect_candidate()
{ {
INVARIANT_CHECK;
ptime now = time_now(); ptime now = time_now();
ptime ptime(now); ptime ptime(now);
iterator candidate = m_peers.end(); iterator candidate = m_peers.end();
@ -646,11 +654,20 @@ namespace libtorrent
if (m_torrent->is_paused()) return; if (m_torrent->is_paused()) return;
// remove old disconnected peers from the list // remove old disconnected peers from the list
m_peers.erase( for (iterator i = m_peers.begin(); i != m_peers.end();)
std::remove_if(m_peers.begin() {
, m_peers.end() // this timeout has to be customizable!
, old_disconnected_peer()) if (i->connection == 0
, m_peers.end()); && i->connected != min_time()
&& time_now() - i->connected > minutes(120))
{
m_peers.erase(i++);
}
else
{
++i;
}
}
// ------------------------------------- // -------------------------------------
// maintain the number of connections // maintain the number of connections
@ -1131,6 +1148,8 @@ namespace libtorrent
bool policy::unchoke_one_peer() bool policy::unchoke_one_peer()
{ {
INVARIANT_CHECK;
iterator p = find_unchoke_candidate(); iterator p = find_unchoke_candidate();
if (p == m_peers.end()) return false; if (p == m_peers.end()) return false;
assert(p->connection); assert(p->connection);
@ -1145,6 +1164,8 @@ namespace libtorrent
void policy::choke_one_peer() void policy::choke_one_peer()
{ {
INVARIANT_CHECK;
iterator p = find_choke_candidate(); iterator p = find_choke_candidate();
if (p == m_peers.end()) return; if (p == m_peers.end()) return;
assert(p->connection); assert(p->connection);
@ -1156,6 +1177,8 @@ namespace libtorrent
bool policy::connect_one_peer() bool policy::connect_one_peer()
{ {
INVARIANT_CHECK;
if(m_torrent->num_peers() >= m_torrent->m_connections_quota.given) if(m_torrent->num_peers() >= m_torrent->m_connections_quota.given)
return false; return false;
@ -1288,6 +1311,8 @@ namespace libtorrent
#ifndef NDEBUG #ifndef NDEBUG
bool policy::has_connection(const peer_connection* c) bool policy::has_connection(const peer_connection* c)
{ {
INVARIANT_CHECK;
assert(c); assert(c);
assert((c->proxy() == tcp::endpoint() && c->remote() == c->get_socket()->remote_endpoint()) assert((c->proxy() == tcp::endpoint() && c->remote() == c->get_socket()->remote_endpoint())
|| c->proxy() == c->get_socket()->remote_endpoint()); || c->proxy() == c->get_socket()->remote_endpoint());
@ -1313,6 +1338,8 @@ namespace libtorrent
{ {
++total_connections; ++total_connections;
if (!i->connection) continue; if (!i->connection) continue;
assert(i->connection->peer_info_struct() == 0
|| i->connection->peer_info_struct() == &*i);
++nonempty_connections; ++nonempty_connections;
if (!i->connection->is_disconnecting()) if (!i->connection->is_disconnecting())
++connected_peers; ++connected_peers;