X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Fserver.h;h=b925031eb2df667cfff90f64a71eacdf3ecb6d7f;hb=02f028d271677b3b3669b5cdfda1597108a34b80;hp=398401a555dd1eff784ad1d2289677e5258660f2;hpb=28dbf4fd074d2046a3c8ddebac9a537a80fd457a;p=dcpomatic.git diff --git a/src/lib/server.h b/src/lib/server.h index 398401a55..b925031eb 100644 --- a/src/lib/server.h +++ b/src/lib/server.h @@ -17,6 +17,9 @@ */ +#ifndef DCPOMATIC_SERVER_H +#define DCPOMATIC_SERVER_H + /** @file src/server.h * @brief Class to describe a server to which we can send * encoding work, and a class to implement such a server. @@ -26,8 +29,10 @@ #include #include #include +#include #include #include "log.h" +#include "exceptions.h" class Socket; @@ -41,6 +46,11 @@ namespace cxml { class ServerDescription { public: + ServerDescription () + : _host_name ("") + , _threads (1) + {} + /** @param h Server host name or IP address in string form. * @param t Number of threads to use on the server. */ @@ -49,7 +59,7 @@ public: , _threads (t) {} - ServerDescription (boost::shared_ptr); + /* Default copy constructor is fine */ /** @return server's host name or IP address in string form */ std::string host_name () const { @@ -69,10 +79,6 @@ public: _threads = t; } - void as_xml (xmlpp::Node *) const; - - static ServerDescription * create_from_metadata (std::string v); - private: /** server's host name */ std::string _host_name; @@ -80,20 +86,40 @@ private: int _threads; }; -class Server +class Server : public ExceptionStore, public boost::noncopyable { public: - Server (boost::shared_ptr log); + Server (boost::shared_ptr log, bool verbose); void run (int num_threads); private: void worker_thread (); - int process (boost::shared_ptr socket); + int process (boost::shared_ptr socket, struct timeval &, struct timeval &); + void broadcast_thread (); + void broadcast_received (); std::vector _worker_threads; std::list > _queue; boost::mutex _worker_mutex; - boost::condition _worker_condition; + boost::condition _full_condition; + boost::condition _empty_condition; boost::shared_ptr _log; + bool _verbose; + + struct Broadcast { + + Broadcast () + : thread (0) + , socket (0) + {} + + boost::thread* thread; + boost::asio::ip::udp::socket* socket; + char buffer[64]; + boost::asio::ip::udp::endpoint send_endpoint; + + } _broadcast; }; + +#endif