added some comments to time-critical-pieces

This commit is contained in:
Arvid Norberg 2011-08-05 07:56:07 +00:00
parent 109e527568
commit 38b91cba40
1 changed files with 10 additions and 1 deletions

View File

@ -7011,6 +7011,9 @@ namespace libtorrent
{ {
TORRENT_ASSERT(m_ses.is_network_thread()); TORRENT_ASSERT(m_ses.is_network_thread());
// build a list of peers and sort it by download_queue_time // build a list of peers and sort it by download_queue_time
// we use this sorted list to determine which peer we should
// request a block from. The higher up a peer is in the list,
// the sooner we will fully download the block we request.
std::vector<peer_connection*> peers; std::vector<peer_connection*> peers;
peers.reserve(m_connections.size()); peers.reserve(m_connections.size());
std::remove_copy_if(m_connections.begin(), m_connections.end() std::remove_copy_if(m_connections.begin(), m_connections.end()
@ -7028,6 +7031,9 @@ namespace libtorrent
ptime now = time_now(); ptime now = time_now();
// now, iterate over all time critical pieces, in order of importance, and
// request them from the peers, in order of responsiveness. i.e. request
// the most time critical pieces from the fastest peers.
for (std::list<time_critical_piece>::iterator i = m_time_critical_pieces.begin() for (std::list<time_critical_piece>::iterator i = m_time_critical_pieces.begin()
, end(m_time_critical_pieces.end()); i != end; ++i) , end(m_time_critical_pieces.end()); i != end; ++i)
{ {
@ -7035,16 +7041,19 @@ namespace libtorrent
+ milliseconds(m_average_piece_time + m_piece_time_deviation * 4)) + milliseconds(m_average_piece_time + m_piece_time_deviation * 4))
{ {
// don't request pieces whose deadline is too far in the future // don't request pieces whose deadline is too far in the future
// this is one of the termination conditions. We don't want to
// send requests for all pieces in the torrent right away
break; break;
} }
// loop until every block has been requested from // loop until every block has been requested from this piece (i->piece)
do do
{ {
// pick the peer with the lowest download_queue_time that has i->piece // pick the peer with the lowest download_queue_time that has i->piece
std::vector<peer_connection*>::iterator p = std::find_if(peers.begin(), peers.end() std::vector<peer_connection*>::iterator p = std::find_if(peers.begin(), peers.end()
, boost::bind(&peer_connection::has_piece, _1, i->piece)); , boost::bind(&peer_connection::has_piece, _1, i->piece));
// obviously we'll have to skip it if we don't have a peer that has this piece
if (p == peers.end()) break; if (p == peers.end()) break;
peer_connection& c = **p; peer_connection& c = **p;