X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fserver.h;h=97bc26fd896b130d777426a41c680e1a58ca1bbc;hp=7470814431e1c53822d8fd18e443006885506b4e;hb=aeb835a18c8df347e0ed68fb24631b320abeb611;hpb=ce799a03297e4961dc203ceae0dcc41d80a44aa8 diff --git a/src/lib/server.h b/src/lib/server.h index 747081443..97bc26fd8 100644 --- a/src/lib/server.h +++ b/src/lib/server.h @@ -17,75 +17,69 @@ */ +#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. + * @brief Server class. */ -#include +#include "exception_store.h" #include #include #include -#include "log.h" - -/** @class ServerDescription - * @brief Class to describe a server to which we can send encoding work. - */ -class ServerDescription -{ -public: - /** @param h Server host name or IP address in string form. - * @param t Number of threads to use on the server. - */ - ServerDescription (std::string h, int t) - : _host_name (h) - , _threads (t) - {} - - /** @return server's host name or IP address in string form */ - std::string host_name () const { - return _host_name; - } - - /** @return number of threads to use on the server */ - int threads () const { - return _threads; - } - - void set_host_name (std::string n) { - _host_name = n; - } - - void set_threads (int t) { - _threads = t; - } - - std::string as_metadata () const; - - static ServerDescription * create_from_metadata (std::string v); +#include -private: - /** server's host name */ - std::string _host_name; - /** number of threads to use on the server */ - int _threads; -}; +class Socket; +class Log; -class Server +/** @class Server + * @brief A class to run a server which can accept requests to perform JPEG2000 + * encoding work. + */ +class Server : public ExceptionStore, public boost::noncopyable { public: - Server (Log* log); + Server (boost::shared_ptr log, bool verbose); + ~Server (); 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 (); + void start_accept (); + void handle_accept (boost::shared_ptr, boost::system::error_code const &); + + bool _terminate; - boost::asio::io_service _io_service; std::vector _worker_threads; - std::list > _queue; + std::list > _queue; boost::mutex _worker_mutex; - boost::condition _worker_condition; - Log* _log; + boost::condition _full_condition; + boost::condition _empty_condition; + boost::shared_ptr _log; + bool _verbose; + + boost::asio::io_service _io_service; + boost::asio::ip::tcp::acceptor _acceptor; + + 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; + boost::asio::io_service io_service; + + } _broadcast; }; + +#endif