X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdecoder_factory.cc;h=2ded95fefe1b343609f62959dd29b3c7a1edfa08;hb=5a649b6d803697388925d7cd64ec5f0da345f865;hp=7f53c9a4b0b8a34a62d12ed8cd012b3f772dd000;hpb=b0f078d851e2a84d2f9d2ae085f6aad837747eb1;p=dcpomatic.git diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc index 7f53c9a4b..2ded95fef 100644 --- a/src/lib/decoder_factory.cc +++ b/src/lib/decoder_factory.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2016 Carl Hetherington + Copyright (C) 2016-2019 Carl Hetherington This file is part of DCP-o-matic. @@ -24,62 +24,69 @@ #include "dcp_decoder.h" #include "image_content.h" #include "image_decoder.h" -#include "text_subtitle_content.h" -#include "text_subtitle_decoder.h" +#include "string_text_file_content.h" +#include "string_text_file_decoder.h" #include "dcp_subtitle_content.h" #include "dcp_subtitle_decoder.h" #include "video_mxf_content.h" #include "video_mxf_decoder.h" +#include "timer.h" #include using std::list; using boost::shared_ptr; using boost::dynamic_pointer_cast; +template +shared_ptr +maybe_cast (shared_ptr d) +{ + if (!d) { + return shared_ptr (); + } + return dynamic_pointer_cast (d); +} + +/** + @param tolerant true to proceed in the face of `survivable' errors, otherwise false. + @param old_decoder A `used' decoder that has been previously made for this piece of content, or 0 +*/ shared_ptr -decoder_factory (shared_ptr content, list > old_image_decoders, shared_ptr log, bool fast) +decoder_factory (shared_ptr film, shared_ptr content, bool fast, bool tolerant, shared_ptr old_decoder) { shared_ptr fc = dynamic_pointer_cast (content); if (fc) { - return shared_ptr (new FFmpegDecoder (fc, log, fast)); + return shared_ptr (new FFmpegDecoder(film, fc, fast)); } shared_ptr dc = dynamic_pointer_cast (content); if (dc) { - return shared_ptr (new DCPDecoder (dc, log, fast)); + try { + return shared_ptr (new DCPDecoder(film, dc, fast, tolerant, maybe_cast(old_decoder))); + } catch (KDMError& e) { + /* This will be found and reported to the user when the content is examined */ + return shared_ptr(); + } } shared_ptr ic = dynamic_pointer_cast (content); if (ic) { - shared_ptr decoder; - - /* See if we can re-use an old ImageDecoder */ - BOOST_FOREACH (shared_ptr i, old_image_decoders) { - if (i->content() == ic) { - decoder = i; - } - } - - if (!decoder) { - decoder.reset (new ImageDecoder (ic, log)); - } - - return decoder; + return shared_ptr (new ImageDecoder(film, ic)); } - shared_ptr rc = dynamic_pointer_cast (content); + shared_ptr rc = dynamic_pointer_cast (content); if (rc) { - return shared_ptr (new TextSubtitleDecoder (rc)); + return shared_ptr (new StringTextFileDecoder(film, rc)); } shared_ptr dsc = dynamic_pointer_cast (content); if (dsc) { - return shared_ptr (new DCPSubtitleDecoder (dsc)); + return shared_ptr (new DCPSubtitleDecoder(film, dsc)); } shared_ptr vmc = dynamic_pointer_cast (content); if (vmc) { - return shared_ptr (new VideoMXFDecoder (vmc, log)); + return shared_ptr (new VideoMXFDecoder(film, vmc)); } return shared_ptr ();