X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftranscoder.h;h=007065b658cd7240f15001f1361f549aa1378493;hb=853b8641ee7fb8348302c0daae838c4891769b1d;hp=4a9667b3c5165b95aa9f8aeea2786b206f184b56;hpb=3ce37f08e98b9c3a238fb1c9a6184fb7fd4e5667;p=dcpomatic.git diff --git a/src/lib/transcoder.h b/src/lib/transcoder.h index 4a9667b3c..007065b65 100644 --- a/src/lib/transcoder.h +++ b/src/lib/transcoder.h @@ -17,8 +17,9 @@ */ +#include "types.h" + /** @file src/transcoder.h - * @brief A class which takes a FilmState and some Options, then uses those to transcode a Film. * * A decoder is selected according to the content type, and the encoder can be specified * as a parameter to the constructor. @@ -27,40 +28,30 @@ class Film; class Job; class Encoder; -class FilmState; -class Matcher; class VideoFilter; -class Gain; -class VideoDecoder; -class AudioDecoder; -class DelayLine; -class Options; +class Player; /** @class Transcoder - * @brief A class which takes a FilmState and some Options, then uses those to transcode a Film. * * A decoder is selected according to the content type, and the encoder can be specified * as a parameter to the constructor. */ -class Transcoder +class Transcoder : public boost::noncopyable { public: - Transcoder (boost::shared_ptr f, boost::shared_ptr o, Job* j, boost::shared_ptr e); + Transcoder ( + boost::shared_ptr f, + boost::shared_ptr j + ); void go (); - boost::shared_ptr video_decoder () const { - return _decoders.first; - } + float current_encoding_rate () const; + int video_frames_out () const; -protected: +private: /** A Job that is running this Transcoder, or 0 */ - Job* _job; - /** The encoder that we will use */ + boost::shared_ptr _job; + boost::shared_ptr _player; boost::shared_ptr _encoder; - /** The decoders that we will use */ - std::pair, boost::shared_ptr > _decoders; - boost::shared_ptr _matcher; - boost::shared_ptr _delay_line; - boost::shared_ptr _gain; };