added more asserts related to the invariance between the peer connections' request queue and the piece picker

This commit is contained in:
Arvid Norberg 2006-12-16 02:19:53 +00:00
parent 0bad3bcc48
commit 400a2fe82a
1 changed files with 58 additions and 5 deletions

View File

@ -598,22 +598,23 @@ namespace libtorrent
#endif #endif
m_peer_choked = true; m_peer_choked = true;
t->get_policy().choked(*this); t->get_policy().choked(*this);
if (!t->is_seed()) if (!t->is_seed())
{ {
piece_picker& p = t->picker();
// remove all pieces from this peers download queue and // remove all pieces from this peers download queue and
// remove the 'downloading' flag from piece_picker. // remove the 'downloading' flag from piece_picker.
for (std::deque<piece_block>::iterator i = m_download_queue.begin(); for (std::deque<piece_block>::iterator i = m_download_queue.begin();
i != m_download_queue.end(); ++i) i != m_download_queue.end(); ++i)
{ {
t->picker().abort_download(*i); p.abort_download(*i);
} }
for (std::deque<piece_block>::const_iterator i = m_request_queue.begin() for (std::deque<piece_block>::const_iterator i = m_request_queue.begin()
, end(m_request_queue.end()); i != end; ++i) , end(m_request_queue.end()); i != end; ++i)
{ {
// since this piece was skipped, clear it and allow it to // since this piece was skipped, clear it and allow it to
// be requested from other peers // be requested from other peers
t->picker().abort_download(*i); p.abort_download(*i);
} }
} }
@ -621,7 +622,22 @@ namespace libtorrent
m_request_queue.clear(); m_request_queue.clear();
#ifndef NDEBUG #ifndef NDEBUG
// t->picker().integrity_check(m_torrent); if (!t->is_seed())
{
piece_picker& p = t->picker();
const std::vector<piece_picker::downloading_piece>& dlq = p.get_download_queue();
const int blocks_per_piece = static_cast<int>(
t->torrent_file().piece_length() / t->block_size());
for (std::vector<piece_picker::downloading_piece>::const_iterator i =
dlq.begin(); i != dlq.end(); ++i)
{
for (int j = 0; j < blocks_per_piece; ++j)
{
assert(i->info[j].peer != m_remote);
}
}
}
#endif #endif
} }
@ -983,7 +999,11 @@ namespace libtorrent
// if we're already seeding, don't bother, // if we're already seeding, don't bother,
// just ignore it // just ignore it
if (t->is_seed()) return; if (t->is_seed())
{
t->received_redundant_data(p.length);
return;
}
piece_picker& picker = t->picker(); piece_picker& picker = t->picker();
piece_manager& fs = t->filesystem(); piece_manager& fs = t->filesystem();
@ -1498,6 +1518,19 @@ namespace libtorrent
#ifndef NDEBUG #ifndef NDEBUG
if (!t->is_seed()) if (!t->is_seed())
{ {
piece_picker& p = t->picker();
const std::vector<piece_picker::downloading_piece>& dlq = p.get_download_queue();
const int blocks_per_piece = static_cast<int>(
t->torrent_file().piece_length() / t->block_size());
for (std::vector<piece_picker::downloading_piece>::const_iterator i =
dlq.begin(); i != dlq.end(); ++i)
{
for (int j = 0; j < blocks_per_piece; ++j)
{
assert(i->info[j].peer != m_remote);
}
}
assert(m_download_queue.empty()); assert(m_download_queue.empty());
assert(m_request_queue.empty()); assert(m_request_queue.empty());
} }
@ -1625,6 +1658,26 @@ namespace libtorrent
m_request_queue.pop_back(); m_request_queue.pop_back();
} }
#ifndef NDEBUG
if (!t->is_seed())
{
piece_picker& p = t->picker();
const std::vector<piece_picker::downloading_piece>& dlq = p.get_download_queue();
const int blocks_per_piece = static_cast<int>(
t->torrent_file().piece_length() / t->block_size());
for (std::vector<piece_picker::downloading_piece>::const_iterator i =
dlq.begin(); i != dlq.end(); ++i)
{
for (int j = 0; j < blocks_per_piece; ++j)
{
assert(i->info[j].peer != m_remote);
}
}
}
#endif
// TODO: If we have a limited number of upload // TODO: If we have a limited number of upload
// slots, choke this peer // slots, choke this peer