X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftranscoder.h;h=007065b658cd7240f15001f1361f549aa1378493;hb=86461ade4087f8473c1e8b063907d92884813843;hp=b0c263d07823f6450a6daa725a63bb6852df5976;hpb=38ab054c2ec22a853ee6abbe3f3683d153e9bb63;p=dcpomatic.git diff --git a/src/lib/transcoder.h b/src/lib/transcoder.h index b0c263d07..007065b65 100644 --- a/src/lib/transcoder.h +++ b/src/lib/transcoder.h @@ -17,55 +17,41 @@ */ +#include "types.h" + /** @file src/transcoder.h - * @brief A class which takes a Film and some Options, then uses those to transcode the film. * * A decoder is selected according to the content type, and the encoder can be specified * as a parameter to the constructor. */ -#include "decoder_factory.h" - class Film; class Job; class Encoder; -class Matcher; class VideoFilter; -class Gain; -class VideoDecoder; -class AudioDecoder; -class DelayLine; +class Player; /** @class Transcoder - * @brief A class which takes a Film and some Options, then uses those to transcode the 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, - DecodeOptions o, - Job* j, - boost::shared_ptr e + boost::shared_ptr f, + boost::shared_ptr j ); void go (); - boost::shared_ptr video_decoder () const { - return _decoders.video; - } + 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 */ - Decoders _decoders; - boost::shared_ptr _matcher; - boost::shared_ptr _delay_line; - boost::shared_ptr _gain; };