X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftranscoder.h;h=ed0a6b1b561bb45a628080819d0866944e8a37f8;hb=8d58a7c5f4320ad5c111e336c45e44d6b51ab509;hp=b3c8f888b1106dfd4ffb6753ae247672ded2fff4;hpb=5fd5e78c51bd5630f6777001db5aa25103218c22;p=dcpomatic.git diff --git a/src/lib/transcoder.h b/src/lib/transcoder.h index b3c8f888b..ed0a6b1b5 100644 --- a/src/lib/transcoder.h +++ b/src/lib/transcoder.h @@ -18,40 +18,33 @@ */ #include "types.h" - -/** @file src/transcoder.h - * - * A decoder is selected according to the content type, and the encoder can be specified - * as a parameter to the constructor. - */ +#include "encoder.h" class Film; -class Job; class Encoder; class VideoFilter; class Player; -/** @class Transcoder - * - * 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 */ +class Transcoder : public boost::noncopyable { public: - Transcoder ( - boost::shared_ptr f, - boost::shared_ptr j - ); + Transcoder (boost::shared_ptr, boost::shared_ptr); void go (); float current_encoding_rate () const; int video_frames_out () const; + /** @return true if we are in the process of calling Encoder::process_end */ + bool finishing () const { + return _finishing; + } + private: - /** A Job that is running this Transcoder, or 0 */ - boost::shared_ptr _job; + boost::shared_ptr _film; boost::shared_ptr _player; + boost::shared_ptr _writer; boost::shared_ptr _encoder; + bool _finishing; };