X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fserver.h;h=a9b4b1c1c8982ed9d57c615c9cee6fcfd9df0324;hb=2d5b8cdde08044d323aa7193dfac6c9f8bca7131;hp=77b51d0798ff11da731783b63f9c624301540be1;hpb=373f010a7f04add1f49169cbaa60cb7ae5f508d4;p=dcpomatic.git diff --git a/src/lib/server.h b/src/lib/server.h index 77b51d079..a9b4b1c1c 100644 --- a/src/lib/server.h +++ b/src/lib/server.h @@ -32,6 +32,7 @@ #include #include #include "log.h" +#include "exceptions.h" class Socket; @@ -58,8 +59,6 @@ public: , _threads (t) {} - ServerDescription (boost::shared_ptr); - /* Default copy constructor is fine */ /** @return server's host name or IP address in string form */ @@ -80,10 +79,6 @@ public: _threads = t; } - void as_xml (xmlpp::Node *) const; - - static boost::optional create_from_metadata (std::string); - private: /** server's host name */ std::string _host_name; @@ -91,22 +86,39 @@ private: int _threads; }; -class Server : public boost::noncopyable +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::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