Merge master and multifarious hackery.
[dcpomatic.git] / src / lib / server.h
1 /*
2     Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 /** @file src/server.h
21  *  @brief Class to describe a server to which we can send
22  *  encoding work, and a class to implement such a server.
23  */
24
25 #include <string>
26 #include <boost/thread.hpp>
27 #include <boost/asio.hpp>
28 #include <boost/thread/condition.hpp>
29 #include <libxml++/libxml++.h>
30 #include "log.h"
31
32 class Socket;
33
34 namespace cxml {
35         class Node;
36 }
37
38 /** @class ServerDescription
39  *  @brief Class to describe a server to which we can send encoding work.
40  */
41 class ServerDescription
42 {
43 public:
44         /** @param h Server host name or IP address in string form.
45          *  @param t Number of threads to use on the server.
46          */
47         ServerDescription (std::string h, int t)
48                 : _host_name (h)
49                 , _threads (t)
50         {}
51
52         ServerDescription (boost::shared_ptr<const cxml::Node>);
53         
54         /** @return server's host name or IP address in string form */
55         std::string host_name () const {
56                 return _host_name;
57         }
58
59         /** @return number of threads to use on the server */
60         int threads () const {
61                 return _threads;
62         }
63
64         void set_host_name (std::string n) {
65                 _host_name = n;
66         }
67
68         void set_threads (int t) {
69                 _threads = t;
70         }
71
72         void as_xml (xmlpp::Node *) const;
73         
74         static ServerDescription * create_from_metadata (std::string v);
75
76 private:
77         /** server's host name */
78         std::string _host_name;
79         /** number of threads to use on the server */
80         int _threads;
81 };
82
83 class Server
84 {
85 public:
86         Server (boost::shared_ptr<Log> log);
87
88         void run (int num_threads);
89
90 private:
91         void worker_thread ();
92         int process (boost::shared_ptr<Socket> socket);
93
94         std::vector<boost::thread *> _worker_threads;
95         std::list<boost::shared_ptr<Socket> > _queue;
96         boost::mutex _worker_mutex;
97         boost::condition _worker_condition;
98         boost::shared_ptr<Log> _log;
99 };