X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fserver.h;h=97bc26fd896b130d777426a41c680e1a58ca1bbc;hp=b340bba077953c7320c0fb9f1820e3ca2cf2a556;hb=d499ec381ea5fbbae954531be9d66c9cc723c230;hpb=74fe68e5895654e27a7cf8097917c1e95fa89519 diff --git a/src/lib/server.h b/src/lib/server.h index b340bba07..97bc26fd8 100644 --- a/src/lib/server.h +++ b/src/lib/server.h @@ -21,71 +21,22 @@ #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 -#include -#include "log.h" -#include "exceptions.h" +#include class Socket; +class Log; -namespace cxml { - class Node; -} - -/** @class ServerDescription - * @brief Class to describe a server to which we can send encoding work. +/** @class Server + * @brief A class to run a server which can accept requests to perform JPEG2000 + * encoding work. */ -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. - */ - ServerDescription (std::string h, int t) - : _host_name (h) - , _threads (t) - {} - - /* Default copy constructor is fine */ - - /** @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; - } - -private: - /** server's host name */ - std::string _host_name; - /** number of threads to use on the server */ - int _threads; -}; - class Server : public ExceptionStore, public boost::noncopyable { public: @@ -115,21 +66,19 @@ private: boost::asio::io_service _io_service; boost::asio::ip::tcp::acceptor _acceptor; - int _num_threads; - 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; };