forked from premiere/premiere-libtorrent
more use of auto and minor code refactor in routing_table.cpp
This commit is contained in:
parent
9bf0658090
commit
7cc2619aad
|
@ -63,7 +63,7 @@ namespace {
|
||||||
template <typename T, typename K>
|
template <typename T, typename K>
|
||||||
void erase_one(T& container, K const& key)
|
void erase_one(T& container, K const& key)
|
||||||
{
|
{
|
||||||
typename T::iterator i = container.find(key);
|
auto const i = container.find(key);
|
||||||
TORRENT_ASSERT(i != container.end());
|
TORRENT_ASSERT(i != container.end());
|
||||||
container.erase(i);
|
container.erase(i);
|
||||||
}
|
}
|
||||||
|
@ -244,10 +244,8 @@ node_entry const* routing_table::next_refresh()
|
||||||
node_entry* candidate = nullptr;
|
node_entry* candidate = nullptr;
|
||||||
|
|
||||||
// this will have a bias towards pinging nodes close to us first.
|
// this will have a bias towards pinging nodes close to us first.
|
||||||
// TODO: why idx is never used here?
|
|
||||||
int idx = int(m_buckets.size()) - 1;
|
|
||||||
for (table_t::reverse_iterator i = m_buckets.rbegin()
|
for (table_t::reverse_iterator i = m_buckets.rbegin()
|
||||||
, end(m_buckets.rend()); i != end; ++i, --idx)
|
, end(m_buckets.rend()); i != end; ++i)
|
||||||
{
|
{
|
||||||
for (bucket_t::iterator j = i->live_nodes.begin()
|
for (bucket_t::iterator j = i->live_nodes.begin()
|
||||||
, end2(i->live_nodes.end()); j != end2; ++j)
|
, end2(i->live_nodes.end()); j != end2; ++j)
|
||||||
|
@ -293,7 +291,7 @@ routing_table::table_t::iterator routing_table::find_bucket(node_id const& id)
|
||||||
TORRENT_ASSERT(bucket_index < int(m_buckets.size()));
|
TORRENT_ASSERT(bucket_index < int(m_buckets.size()));
|
||||||
TORRENT_ASSERT(bucket_index >= 0);
|
TORRENT_ASSERT(bucket_index >= 0);
|
||||||
|
|
||||||
table_t::iterator i = m_buckets.begin();
|
auto i = m_buckets.begin();
|
||||||
std::advance(i, bucket_index);
|
std::advance(i, bucket_index);
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
@ -373,7 +371,7 @@ void routing_table::fill_from_replacements(table_t::iterator bucket)
|
||||||
|
|
||||||
while (int(b.size()) < bucket_size && !rb.empty())
|
while (int(b.size()) < bucket_size && !rb.empty())
|
||||||
{
|
{
|
||||||
bucket_t::iterator j = std::find_if(rb.begin(), rb.end(), std::bind(&node_entry::pinged, _1));
|
auto j = std::find_if(rb.begin(), rb.end(), std::bind(&node_entry::pinged, _1));
|
||||||
if (j == rb.end()) j = rb.begin();
|
if (j == rb.end()) j = rb.begin();
|
||||||
b.push_back(*j);
|
b.push_back(*j);
|
||||||
rb.erase(j);
|
rb.erase(j);
|
||||||
|
@ -395,7 +393,7 @@ void routing_table::remove_node_internal(node_entry* n, bucket_t& b)
|
||||||
|
|
||||||
void routing_table::remove_node(node_entry* n
|
void routing_table::remove_node(node_entry* n
|
||||||
, routing_table::table_t::iterator bucket)
|
, routing_table::table_t::iterator bucket)
|
||||||
{
|
{
|
||||||
INVARIANT_CHECK;
|
INVARIANT_CHECK;
|
||||||
|
|
||||||
remove_node_internal(n, bucket->replacements);
|
remove_node_internal(n, bucket->replacements);
|
||||||
|
@ -543,7 +541,7 @@ routing_table::add_node_status_t routing_table::add_node_impl(node_entry e)
|
||||||
// don't add ourself
|
// don't add ourself
|
||||||
if (e.id == m_id) return failed_to_add;
|
if (e.id == m_id) return failed_to_add;
|
||||||
|
|
||||||
table_t::iterator i = find_bucket(e.id);
|
auto const i = find_bucket(e.id);
|
||||||
bucket_t& b = i->live_nodes;
|
bucket_t& b = i->live_nodes;
|
||||||
bucket_t& rb = i->replacements;
|
bucket_t& rb = i->replacements;
|
||||||
int const bucket_index = int(std::distance(m_buckets.begin(), i));
|
int const bucket_index = int(std::distance(m_buckets.begin(), i));
|
||||||
|
@ -657,7 +655,7 @@ ip_ok:
|
||||||
// we may replace other nodes that aren't pinged
|
// we may replace other nodes that aren't pinged
|
||||||
|
|
||||||
j = std::find_if(b.begin(), b.end()
|
j = std::find_if(b.begin(), b.end()
|
||||||
, [](node_entry const& ne) { return ne.pinged() == false; });
|
, [](node_entry const& ne) { return !ne.pinged(); });
|
||||||
|
|
||||||
if (j != b.end() && !j->pinged())
|
if (j != b.end() && !j->pinged())
|
||||||
{
|
{
|
||||||
|
@ -839,7 +837,7 @@ ip_ok:
|
||||||
// but prefer nodes that haven't been pinged, since they are
|
// but prefer nodes that haven't been pinged, since they are
|
||||||
// less reliable than this one, that has been pinged
|
// less reliable than this one, that has been pinged
|
||||||
j = std::find_if(rb.begin(), rb.end()
|
j = std::find_if(rb.begin(), rb.end()
|
||||||
, [] (node_entry const& ne) { return ne.pinged() == false; });
|
, [] (node_entry const& ne) { return !ne.pinged(); });
|
||||||
if (j == rb.end()) j = rb.begin();
|
if (j == rb.end()) j = rb.begin();
|
||||||
m_ips.erase(j->addr());
|
m_ips.erase(j->addr());
|
||||||
rb.erase(j);
|
rb.erase(j);
|
||||||
|
@ -874,7 +872,7 @@ void routing_table::split_bucket()
|
||||||
// move any node whose (160 - distance_exp(m_id, id)) >= (i - m_buckets.begin())
|
// move any node whose (160 - distance_exp(m_id, id)) >= (i - m_buckets.begin())
|
||||||
// to the new bucket
|
// to the new bucket
|
||||||
int const new_bucket_size = bucket_limit(bucket_index + 1);
|
int const new_bucket_size = bucket_limit(bucket_index + 1);
|
||||||
for (bucket_t::iterator j = b.begin(); j != b.end();)
|
for (auto j = b.begin(); j != b.end();)
|
||||||
{
|
{
|
||||||
int const d = distance_exp(m_id, j->id);
|
int const d = distance_exp(m_id, j->id);
|
||||||
if (d >= 159 - bucket_index)
|
if (d >= 159 - bucket_index)
|
||||||
|
@ -974,11 +972,11 @@ void routing_table::node_failed(node_id const& nid, udp::endpoint const& ep)
|
||||||
// if messages to ourself fails, ignore it
|
// if messages to ourself fails, ignore it
|
||||||
if (nid == m_id) return;
|
if (nid == m_id) return;
|
||||||
|
|
||||||
table_t::iterator i = find_bucket(nid);
|
auto const i = find_bucket(nid);
|
||||||
bucket_t& b = i->live_nodes;
|
bucket_t& b = i->live_nodes;
|
||||||
bucket_t& rb = i->replacements;
|
bucket_t& rb = i->replacements;
|
||||||
|
|
||||||
bucket_t::iterator j = std::find_if(b.begin(), b.end()
|
auto j = std::find_if(b.begin(), b.end()
|
||||||
, [&nid](node_entry const& ne) { return ne.id == nid; });
|
, [&nid](node_entry const& ne) { return ne.id == nid; });
|
||||||
|
|
||||||
if (j == b.end())
|
if (j == b.end())
|
||||||
|
@ -1076,7 +1074,7 @@ void routing_table::find_node(node_id const& target
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::remove_copy_if(b.begin(), b.end(), std::back_inserter(l)
|
std::remove_copy_if(b.begin(), b.end(), std::back_inserter(l)
|
||||||
, [](node_entry const& ne) { return ne.confirmed() == false; });
|
, [](node_entry const& ne) { return !ne.confirmed(); });
|
||||||
}
|
}
|
||||||
|
|
||||||
if (int(l.size()) == count) return;
|
if (int(l.size()) == count) return;
|
||||||
|
@ -1115,7 +1113,7 @@ void routing_table::find_node(node_id const& target
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::remove_copy_if(b.begin(), b.end(), std::back_inserter(l)
|
std::remove_copy_if(b.begin(), b.end(), std::back_inserter(l)
|
||||||
, [](node_entry const& ne) { return ne.confirmed() == false; });
|
, [](node_entry const& ne) { return !ne.confirmed(); });
|
||||||
}
|
}
|
||||||
|
|
||||||
if (int(l.size()) == count) return;
|
if (int(l.size()) == count) return;
|
||||||
|
|
Loading…
Reference in New Issue