Untested first cut.
[dcpomatic.git] / src / lib / server.h
index d06df34e9e649dd84d49a85dc6472f6c5cf2b87a..7470814431e1c53822d8fd18e443006885506b4e 100644 (file)
 
 /** @file src/server.h
  *  @brief Class to describe a server to which we can send
- *  encoding work.
+ *  encoding work, and a class to implement such a server.
  */
 
 #include <string>
+#include <boost/thread.hpp>
+#include <boost/asio.hpp>
+#include <boost/thread/condition.hpp>
+#include "log.h"
 
-/** @class Server
+/** @class ServerDescription
  *  @brief Class to describe a server to which we can send encoding work.
  */
-class Server
+class ServerDescription
 {
 public:
        /** @param h Server host name or IP address in string form.
         *  @param t Number of threads to use on the server.
         */
-       Server (std::string h, int t)
+       ServerDescription (std::string h, int t)
                : _host_name (h)
                , _threads (t)
        {}
@@ -58,7 +62,7 @@ public:
 
        std::string as_metadata () const;
        
-       static Server * create_from_metadata (std::string v);
+       static ServerDescription * create_from_metadata (std::string v);
 
 private:
        /** server's host name */
@@ -66,3 +70,22 @@ private:
        /** number of threads to use on the server */
        int _threads;
 };
+
+class Server
+{
+public:
+       Server (Log* log);
+
+       void run (int num_threads);
+
+private:
+       void worker_thread ();
+       int process (boost::shared_ptr<boost::asio::ip::tcp::socket> socket);
+
+       boost::asio::io_service _io_service;
+       std::vector<boost::thread *> _worker_threads;
+       std::list<boost::shared_ptr<boost::asio::ip::tcp::socket> > _queue;
+       boost::mutex _worker_mutex;
+       boost::condition _worker_condition;
+       Log* _log;
+};