X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fdecoder_factory.cc;h=4b2a594e1e3c365f9b5c692cf7897d594e7994cc;hp=02d7064f4ba6e8b090419c3208a57c2c921c13f4;hb=a5be11a965c2c38442e4e069874e7e21b5b43a5c;hpb=df17bbd25da69fc38eb2dcd8b4a2531cf0bab0bc diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc index 02d7064f4..4b2a594e1 100644 --- a/src/lib/decoder_factory.cc +++ b/src/lib/decoder_factory.cc @@ -37,36 +37,41 @@ using boost::shared_ptr; using boost::dynamic_pointer_cast; shared_ptr -decoder_factory (shared_ptr content, shared_ptr log, bool fast) +decoder_factory (shared_ptr film, shared_ptr content, bool fast) { 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)); + } 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) { - return shared_ptr (new ImageDecoder (ic, log)); + return shared_ptr (new ImageDecoder(film, ic)); } shared_ptr rc = dynamic_pointer_cast (content); if (rc) { - return shared_ptr (new StringTextFileDecoder (rc, log)); + return shared_ptr (new StringTextFileDecoder(film, rc)); } shared_ptr dsc = dynamic_pointer_cast (content); if (dsc) { - return shared_ptr (new DCPSubtitleDecoder (dsc, log)); + 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 ();