2 Copyright (C) 2012-2017 Carl Hetherington <cth@carlh.net>
4 This file is part of DCP-o-matic.
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.
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.
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/>.
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.
25 * A decoder is selected according to the content type, and the encoder can be specified
26 * as a parameter to the constructor.
34 using boost::weak_ptr;
35 using boost::shared_ptr;
37 /** Construct an encoder.
38 * @param film Film that we are encoding.
39 * @param job Job that this encoder is being used in.
41 Encoder::Encoder (shared_ptr<const Film> film, weak_ptr<Job> job)
44 , _player (new Player (film, film->playlist ()))
46 _player_video_connection = _player->Video.connect (bind (&Encoder::video, this, _1, _2));
47 _player_audio_connection = _player->Audio.connect (bind (&Encoder::audio, this, _1, _2));
48 _player_subtitle_connection = _player->Subtitle.connect (bind (&Encoder::subtitle, this, _1, _2));