More OS X packaging tweaks.
[dcpomatic.git] / src / lib / decoder_factory.cc
index c03912094a231df6300cd52a16c8bb24be293c0e..f7f9f4074c52ae50c6e617d1bc22d967f44ff752 100644 (file)
 
 #include <boost/filesystem.hpp>
 #include "ffmpeg_decoder.h"
-#include "tiff_decoder.h"
 #include "imagemagick_decoder.h"
-#include "film_state.h"
+#include "film.h"
+#include "sndfile_decoder.h"
+#include "decoder_factory.h"
 
-using namespace std;
-using namespace boost;
+using std::string;
+using std::pair;
+using std::make_pair;
+using boost::shared_ptr;
+using boost::dynamic_pointer_cast;
 
-shared_ptr<Decoder>
+Decoders
 decoder_factory (
-       shared_ptr<const FilmState> fs, shared_ptr<const Options> o, Job* j, Log* l, bool minimal = false, bool ignore_length = false
+       shared_ptr<Film> f, DecodeOptions o
        )
 {
-       if (filesystem::is_directory (fs->content_path ())) {
-               /* Assume a directory contains TIFFs */
-               return shared_ptr<Decoder> (new TIFFDecoder (fs, o, j, l, minimal, ignore_length));
+       if (f->content().empty()) {
+               return Decoders ();
+       }
+       
+       if (boost::filesystem::is_directory (f->content_path()) || f->content_type() == STILL) {
+               /* A single image file, or a directory of them */
+               return Decoders (
+                       shared_ptr<VideoDecoder> (new ImageMagickDecoder (f, o)),
+                       shared_ptr<AudioDecoder> (new SndfileDecoder (f, o))
+                       );
        }
 
-       if (fs->content_type() == STILL) {
-               /* Always ignore length of decodes of stills, since the decoder finishes very quickly
-                  and it's the encoder that takes the time.
-               */
-               return shared_ptr<Decoder> (new ImageMagickDecoder (fs, o, j, l, minimal, true));
+       shared_ptr<FFmpegDecoder> fd (new FFmpegDecoder (f, o));
+       if (f->use_content_audio()) {
+               return Decoders (fd, fd);
        }
-       
-       return shared_ptr<Decoder> (new FFmpegDecoder (fs, o, j, l, minimal, ignore_length));
+
+       return Decoders (fd, shared_ptr<AudioDecoder> (new SndfileDecoder (f, o)));
 }