+#include <google/protobuf/repeated_field.h>
+
+#include "client.h"
+#include "server.h"
#include "serverpool.h"
+#include "state.pb.h"
using namespace std;
{
delete[] servers;
}
+
+CubemapStateProto ServerPool::serialize()
+{
+ CubemapStateProto state;
+
+ for (int i = 0; i < num_servers; ++i) {
+ CubemapStateProto local_state = servers[i].serialize();
+
+ // The stream state should be identical between the servers, so we only store it once.
+ if (i == 0) {
+ state.mutable_streams()->MergeFrom(local_state.streams());
+ }
+ for (int j = 0; j < local_state.clients_size(); ++j) {
+ state.add_clients()->MergeFrom(local_state.clients(j));
+ }
+ }
+
+ return state;
+}
void ServerPool::add_client(int sock)
{
servers[clients_added++ % num_servers].add_client_from_serialized(client);
}
-void ServerPool::add_stream(const std::string &stream_id)
+void ServerPool::add_stream(const std::string &stream_id, size_t backlog_size)
{
for (int i = 0; i < num_servers; ++i) {
- servers[i].add_stream(stream_id);
+ servers[i].add_stream(stream_id, backlog_size);
}
}
}
}
+void ServerPool::stop()
+{
+ for (int i = 0; i < num_servers; ++i) {
+ servers[i].stop();
+ }
+}
+
vector<ClientStats> ServerPool::get_client_stats() const
{
vector<ClientStats> ret;
servers[i].set_mark_pool(stream_id, mark_pool);
}
}
+
+void ServerPool::set_backlog_size(const std::string &stream_id, size_t new_size)
+{
+ for (int i = 0; i < num_servers; ++i) {
+ servers[i].set_backlog_size(stream_id, new_size);
+ }
+}