summaryrefslogtreecommitdiff
path: root/src/lib/encode_server_finder.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-04-13 01:09:10 +0100
committerCarl Hetherington <cth@carlh.net>2018-04-13 01:09:10 +0100
commit9106e6ed551b13e1b7c7ee2088d54ce0ae430bcf (patch)
treeb147172aa469005bdd7c80095abcd4493e9c92e1 /src/lib/encode_server_finder.cc
parent6dd6676700f830547e9e7c38781f09de5f2a1a00 (diff)
Tidy up to use one list of servers.
Diffstat (limited to 'src/lib/encode_server_finder.cc')
-rw-r--r--src/lib/encode_server_finder.cc79
1 files changed, 25 insertions, 54 deletions
diff --git a/src/lib/encode_server_finder.cc b/src/lib/encode_server_finder.cc
index 06a6a396b..1837101b5 100644
--- a/src/lib/encode_server_finder.cc
+++ b/src/lib/encode_server_finder.cc
@@ -99,27 +99,7 @@ EncodeServerFinder::stop ()
_listen_thread = 0;
boost::mutex::scoped_lock lm (_servers_mutex);
- _good_servers.clear ();
- _bad_servers.clear ();
-}
-
-static bool
-remove_missing (list<EncodeServerDescription>& servers, int since)
-{
- bool removed = false;
- list<EncodeServerDescription>::iterator i = servers.begin();
- while (i != servers.end()) {
- if (i->last_seen_seconds() > since) {
- list<EncodeServerDescription>::iterator j = i;
- ++j;
- servers.erase (i);
- i = j;
- removed = true;
- } else {
- ++i;
- }
- }
- return removed;
+ _servers.clear ();
}
void
@@ -171,9 +151,22 @@ try
/* Discard servers that we haven't seen for a while */
{
boost::mutex::scoped_lock lm (_servers_mutex);
- bool g = remove_missing(_good_servers, 2 * interval);
- bool b = remove_missing(_bad_servers, 2 * interval);
- if (g || b) {
+
+ bool removed = false;
+ list<EncodeServerDescription>::iterator i = _servers.begin();
+ while (i != _servers.end()) {
+ if (i->last_seen_seconds() > 2 * interval) {
+ list<EncodeServerDescription>::iterator j = i;
+ ++j;
+ _servers.erase (i);
+ i = j;
+ removed = true;
+ } else {
+ ++i;
+ }
+ }
+
+ if (removed) {
emit (boost::bind (boost::ref (ServersListChanged)));
}
}
@@ -243,13 +236,8 @@ EncodeServerFinder::handle_accept (boost::system::error_code ec, shared_ptr<Sock
(*found)->set_seen ();
} else {
EncodeServerDescription sd (ip, xml->number_child<int>("Threads"), xml->optional_number_child<int>("Version").get_value_or(0));
- if (sd.link_version() == SERVER_LINK_VERSION) {
- boost::mutex::scoped_lock lm (_servers_mutex);
- _good_servers.push_back (sd);
- } else {
- boost::mutex::scoped_lock lm (_servers_mutex);
- _bad_servers.push_back (sd);
- }
+ boost::mutex::scoped_lock lm (_servers_mutex);
+ _servers.push_back (sd);
emit (boost::bind (boost::ref (ServersListChanged)));
}
@@ -260,21 +248,12 @@ optional<list<EncodeServerDescription>::iterator>
EncodeServerFinder::server_found (string ip)
{
boost::mutex::scoped_lock lm (_servers_mutex);
- list<EncodeServerDescription>::iterator i = _good_servers.begin();
- while (i != _good_servers.end() && i->host_name() != ip) {
+ list<EncodeServerDescription>::iterator i = _servers.begin();
+ while (i != _servers.end() && i->host_name() != ip) {
++i;
}
- if (i != _good_servers.end()) {
- return i;
- }
-
- i = _bad_servers.begin();
- while (i != _bad_servers.end() && i->host_name() != ip) {
- ++i;
- }
-
- if (i != _bad_servers.end()) {
+ if (i != _servers.end()) {
return i;
}
@@ -300,17 +279,10 @@ EncodeServerFinder::drop ()
}
list<EncodeServerDescription>
-EncodeServerFinder::good_servers () const
-{
- boost::mutex::scoped_lock lm (_servers_mutex);
- return _good_servers;
-}
-
-list<EncodeServerDescription>
-EncodeServerFinder::bad_servers () const
+EncodeServerFinder::servers () const
{
boost::mutex::scoped_lock lm (_servers_mutex);
- return _bad_servers;
+ return _servers;
}
void
@@ -319,8 +291,7 @@ EncodeServerFinder::config_changed (Config::Property what)
if (what == Config::USE_ANY_SERVERS || what == Config::SERVERS) {
{
boost::mutex::scoped_lock lm (_servers_mutex);
- _good_servers.clear ();
- _bad_servers.clear ();
+ _servers.clear ();
}
ServersListChanged ();
_search_condition.notify_all ();