864b0fdc1f17db73204199e75c79b8f60c191976
[dcpomatic.git] / src / lib / encode_server_description.h
1 /*
2     Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #ifndef DCPOMATIC_ENCODE_SERVER_DESCRIPTION_H
22 #define DCPOMATIC_ENCODE_SERVER_DESCRIPTION_H
23
24 /** @class EncodeServerDescription
25  *  @brief Class to describe a server to which we can send encoding work.
26  */
27 class EncodeServerDescription
28 {
29 public:
30         EncodeServerDescription ()
31                 : _host_name ("")
32                 , _threads (1)
33                 , _link_version (0)
34         {}
35
36         /** @param h Server host name or IP address in string form.
37          *  @param t Number of threads to use on the server.
38          *  @param l Server link version number of the server.
39          */
40         EncodeServerDescription (std::string h, int t, int l)
41                 : _host_name (h)
42                 , _threads (t)
43                 , _link_version (l)
44         {}
45
46         /* Default copy constructor is fine */
47
48         /** @return server's host name or IP address in string form */
49         std::string host_name () const {
50                 return _host_name;
51         }
52
53         /** @return number of threads to use on the server */
54         int threads () const {
55                 return _threads;
56         }
57
58         int link_version () const {
59                 return _link_version;
60         }
61
62         void set_host_name (std::string n) {
63                 _host_name = n;
64         }
65
66         void set_threads (int t) {
67                 _threads = t;
68         }
69
70 private:
71         /** server's host name */
72         std::string _host_name;
73         /** number of threads to use on the server */
74         int _threads;
75         /** server link (i.e. protocol) version number */
76         int _link_version;
77 };
78
79 #endif