X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fdecoder_factory.cc;h=4b2a594e1e3c365f9b5c692cf7897d594e7994cc;hp=a7367dd244ad709adefe5226c63335b43a237e26;hb=HEAD;hpb=507a389e9c5f84ec1d51e7566e38fbf42f658537 diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc index a7367dd24..1bda93c94 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-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -18,56 +18,86 @@ */ -#include "ffmpeg_content.h" -#include "ffmpeg_decoder.h" + +#include "atmos_mxf_content.h" +#include "atmos_mxf_decoder.h" #include "dcp_content.h" #include "dcp_decoder.h" +#include "dcp_subtitle_content.h" +#include "dcp_subtitle_decoder.h" +#include "ffmpeg_content.h" +#include "ffmpeg_decoder.h" #include "image_content.h" #include "image_decoder.h" -#include "plain_text_file_content.h" -#include "plain_text_file_decoder.h" -#include "dcp_text_content.h" -#include "dcp_text_decoder.h" +#include "string_text_file_content.h" +#include "string_text_file_decoder.h" +#include "timer.h" #include "video_mxf_content.h" #include "video_mxf_decoder.h" -#include + +using std::dynamic_pointer_cast; using std::list; -using boost::shared_ptr; -using boost::dynamic_pointer_cast; +using std::make_shared; +using std::shared_ptr; + +template +shared_ptr +maybe_cast (shared_ptr d) +{ + if (!d) { + return {}; + } + 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, 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); + auto fc = dynamic_pointer_cast (content); if (fc) { - return shared_ptr (new FFmpegDecoder (fc, log, fast)); + return make_shared(film, fc, fast); } - shared_ptr dc = dynamic_pointer_cast (content); + auto dc = dynamic_pointer_cast (content); if (dc) { - return shared_ptr (new DCPDecoder (dc, log, fast)); + try { + return make_shared(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 ic = dynamic_pointer_cast (content); + auto ic = dynamic_pointer_cast (content); if (ic) { - return shared_ptr (new ImageDecoder (ic, log)); + return make_shared(film, ic); } - shared_ptr rc = dynamic_pointer_cast (content); + auto rc = dynamic_pointer_cast (content); if (rc) { - return shared_ptr (new PlainTextFileDecoder (rc, log)); + return make_shared(film, rc); } - shared_ptr dsc = dynamic_pointer_cast (content); + auto dsc = dynamic_pointer_cast (content); if (dsc) { - return shared_ptr (new DCPTextDecoder (dsc, log)); + return make_shared(film, dsc); } - shared_ptr vmc = dynamic_pointer_cast (content); + auto vmc = dynamic_pointer_cast (content); if (vmc) { - return shared_ptr (new VideoMXFDecoder (vmc, log)); + return make_shared(film, vmc); + } + + auto amc = dynamic_pointer_cast (content); + if (amc) { + return make_shared(film, amc); } - return shared_ptr (); + return {}; }