Rename some classes.
[dcpomatic.git] / src / lib / encoder.cc
1 /*
2     Copyright (C) 2012-2017 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 /** @file  src/encoder.cc
22  *  @brief A class which takes a Film and some Options, then uses those to encode the film
23  *  into some output format.
24  *
25  *  A decoder is selected according to the content type, and the encoder can be specified
26  *  as a parameter to the constructor.
27  */
28
29 #include "encoder.h"
30 #include "player.h"
31
32 #include "i18n.h"
33
34 using boost::weak_ptr;
35 using boost::shared_ptr;
36
37 /** Construct an encoder.
38  *  @param film Film that we are encoding.
39  *  @param job Job that this encoder is being used in.
40  */
41 Encoder::Encoder (shared_ptr<const Film> film, weak_ptr<Job> job)
42         : _film (film)
43         , _job (job)
44         , _player (new Player (film, film->playlist ()))
45 {
46         _player->Video.connect (bind (&Encoder::video, this, _1, _2));
47         _player->Audio.connect (bind (&Encoder::audio, this, _1, _2));
48         _player->Subtitle.connect (bind (&Encoder::subtitle, this, _1, _2));
49 }