Try to fix the filter / AVFrame ownership.
[dcpomatic.git] / src / lib / transcoder.h
index 4a9667b3c5165b95aa9f8aeea2786b206f184b56..f5b8ae6e329d3892735bf5d5a4d36f1615c44fc5 100644 (file)
 */
 
 /** @file  src/transcoder.h
- *  @brief A class which takes a FilmState and some Options, then uses those to transcode a Film.
+ *  @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 FilmState;
 class Matcher;
 class VideoFilter;
 class Gain;
 class VideoDecoder;
 class AudioDecoder;
 class DelayLine;
-class Options;
+class Trimmer;
 
 /** @class Transcoder
- *  @brief A class which takes a FilmState and some Options, then uses those to transcode a Film.
+ *  @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.
@@ -45,12 +46,17 @@ class Options;
 class Transcoder
 {
 public:
-       Transcoder (boost::shared_ptr<Film> f, boost::shared_ptr<const Options> o, Job* j, boost::shared_ptr<Encoder> e);
+       Transcoder (
+               boost::shared_ptr<Film> f,
+               DecodeOptions o,
+               Job* j,
+               boost::shared_ptr<Encoder> e
+               );
 
        void go ();
 
        boost::shared_ptr<VideoDecoder> video_decoder () const {
-               return _decoders.first;
+               return _decoders.video;
        }
 
 protected:
@@ -59,8 +65,9 @@ protected:
        /** The encoder that we will use */
        boost::shared_ptr<Encoder> _encoder;
        /** The decoders that we will use */
-       std::pair<boost::shared_ptr<VideoDecoder>, boost::shared_ptr<AudioDecoder> > _decoders;
+       Decoders _decoders;
        boost::shared_ptr<Matcher> _matcher;
        boost::shared_ptr<DelayLine> _delay_line;
        boost::shared_ptr<Gain> _gain;
+       boost::shared_ptr<Trimmer> _trimmer;
 };