removed old code from piece picker and fixed set_priority to not tamper with the download queue
This commit is contained in:
parent
9be3f14dd7
commit
577bda5266
|
@ -530,54 +530,7 @@ namespace libtorrent
|
||||||
m_piece_info[priority].pop_back();
|
m_piece_info[priority].pop_back();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
void piece_picker::remove(int priority, int elem_index)
|
|
||||||
{
|
|
||||||
assert(priority > 0);
|
|
||||||
assert(elem_index >= 0);
|
|
||||||
assert(m_files_checked_called);
|
|
||||||
|
|
||||||
assert(int(m_piece_info.size()) > priority);
|
|
||||||
assert(int(m_piece_info[priority].size()) > elem_index);
|
|
||||||
|
|
||||||
int index = m_piece_info[priority][elem_index];
|
|
||||||
|
|
||||||
piece_pos& p = m_piece_map[index];
|
|
||||||
|
|
||||||
if (p.downloading)
|
|
||||||
{
|
|
||||||
std::vector<downloading_piece>::iterator i
|
|
||||||
= std::find_if(m_downloads.begin(),
|
|
||||||
m_downloads.end(),
|
|
||||||
has_index(index));
|
|
||||||
assert(i != m_downloads.end());
|
|
||||||
m_downloads.erase(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
p.downloading = 0;
|
|
||||||
if (is_ordered(priority))
|
|
||||||
{
|
|
||||||
std::vector<int>& v = m_piece_info[priority];
|
|
||||||
std::vector<int>::iterator i = v.begin() + elem_index;
|
|
||||||
v.erase(i);
|
|
||||||
i = v.begin() + elem_index;
|
|
||||||
for (; i != v.end(); ++i)
|
|
||||||
{
|
|
||||||
--m_piece_map[*i].index;
|
|
||||||
assert(v[m_piece_map[*i].index] == *i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// this will remove elem from the vector without
|
|
||||||
// preserving order
|
|
||||||
index = m_piece_info[priority][elem_index] = m_piece_info[priority].back();
|
|
||||||
// update the entry we moved from the back
|
|
||||||
m_piece_map[index].index = elem_index;
|
|
||||||
m_piece_info[priority].pop_back();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
void piece_picker::restore_piece(int index)
|
void piece_picker::restore_piece(int index)
|
||||||
{
|
{
|
||||||
TORRENT_PIECE_PICKER_INVARIANT_CHECK;
|
TORRENT_PIECE_PICKER_INVARIANT_CHECK;
|
||||||
|
@ -917,19 +870,6 @@ namespace libtorrent
|
||||||
// the piece just got filtered
|
// the piece just got filtered
|
||||||
if (p.have()) ++m_num_have_filtered;
|
if (p.have()) ++m_num_have_filtered;
|
||||||
else ++m_num_filtered;
|
else ++m_num_filtered;
|
||||||
|
|
||||||
if (p.downloading)
|
|
||||||
{
|
|
||||||
std::vector<downloading_piece>::iterator i
|
|
||||||
= std::find_if(m_downloads.begin(),
|
|
||||||
m_downloads.end(),
|
|
||||||
has_index(index));
|
|
||||||
assert(i != m_downloads.end());
|
|
||||||
m_downloads.erase(i);
|
|
||||||
assert(std::find_if(m_downloads.begin(), m_downloads.end()
|
|
||||||
, has_index(index)) == m_downloads.end());
|
|
||||||
}
|
|
||||||
p.downloading = 0;
|
|
||||||
}
|
}
|
||||||
else if (new_piece_priority != piece_pos::filter_priority
|
else if (new_piece_priority != piece_pos::filter_priority
|
||||||
&& p.piece_priority == piece_pos::filter_priority)
|
&& p.piece_priority == piece_pos::filter_priority)
|
||||||
|
@ -1337,35 +1277,7 @@ namespace libtorrent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
void piece_picker::mark_as_finished(piece_block block, const peer_id& peer)
|
|
||||||
{
|
|
||||||
#ifndef NDEBUG
|
|
||||||
integrity_check();
|
|
||||||
#endif
|
|
||||||
assert(block.piece_index >= 0);
|
|
||||||
assert(block.block_index >= 0);
|
|
||||||
assert(block.piece_index < m_piece_map.size());
|
|
||||||
assert(block.block_index < blocks_in_piece(block.piece_index));
|
|
||||||
|
|
||||||
assert(m_piece_map[block.piece_index].downloading == 1);
|
|
||||||
|
|
||||||
std::vector<downloading_piece>::iterator i
|
|
||||||
= std::find_if(m_downloads.begin(), m_downloads.end(), has_index(block.piece_index));
|
|
||||||
assert(i != m_downloads.end());
|
|
||||||
i->finished_blocks[block.block_index] = 1;
|
|
||||||
// the block may have been requested, then cancled
|
|
||||||
// and requested by a peer that disconnects
|
|
||||||
// that way we can actually receive the piece
|
|
||||||
// without the requested bit is set.
|
|
||||||
i->requested_blocks[block.block_index] = 1;
|
|
||||||
i->info[block.block_index].num_downloads++;
|
|
||||||
i->info[block.block_index].peer = peer;
|
|
||||||
#ifndef NDEBUG
|
|
||||||
integrity_check();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
void piece_picker::get_downloaders(std::vector<tcp::endpoint>& d, int index) const
|
void piece_picker::get_downloaders(std::vector<tcp::endpoint>& d, int index) const
|
||||||
{
|
{
|
||||||
assert(index >= 0 && index <= (int)m_piece_map.size());
|
assert(index >= 0 && index <= (int)m_piece_map.size());
|
||||||
|
|
Loading…
Reference in New Issue