projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Make FileError say what path the problem was with.
[dcpomatic.git]
/
src
/
lib
/
decoder_factory.cc
diff --git
a/src/lib/decoder_factory.cc
b/src/lib/decoder_factory.cc
index dc01a043a56cf49aa1df7c0baf311be1aa6e9301..4b2a594e1e3c365f9b5c692cf7897d594e7994cc 100644
(file)
--- a/
src/lib/decoder_factory.cc
+++ b/
src/lib/decoder_factory.cc
@@
-24,8
+24,8
@@
#include "dcp_decoder.h"
#include "image_content.h"
#include "image_decoder.h"
#include "dcp_decoder.h"
#include "image_content.h"
#include "image_decoder.h"
-#include "
text_subtit
le_content.h"
-#include "
text_subtit
le_decoder.h"
+#include "
string_text_fi
le_content.h"
+#include "
string_text_fi
le_decoder.h"
#include "dcp_subtitle_content.h"
#include "dcp_subtitle_decoder.h"
#include "video_mxf_content.h"
#include "dcp_subtitle_content.h"
#include "dcp_subtitle_decoder.h"
#include "video_mxf_content.h"
@@
-37,36
+37,41
@@
using boost::shared_ptr;
using boost::dynamic_pointer_cast;
shared_ptr<Decoder>
using boost::dynamic_pointer_cast;
shared_ptr<Decoder>
-decoder_factory (shared_ptr<const
Content> content, shared_ptr<Log> log
, bool fast)
+decoder_factory (shared_ptr<const
Film> film, shared_ptr<const Content> content
, bool fast)
{
shared_ptr<const FFmpegContent> fc = dynamic_pointer_cast<const FFmpegContent> (content);
if (fc) {
{
shared_ptr<const FFmpegContent> fc = dynamic_pointer_cast<const FFmpegContent> (content);
if (fc) {
- return shared_ptr<Decoder> (new FFmpegDecoder
(fc, log
, fast));
+ return shared_ptr<Decoder> (new FFmpegDecoder
(film, fc
, fast));
}
shared_ptr<const DCPContent> dc = dynamic_pointer_cast<const DCPContent> (content);
if (dc) {
}
shared_ptr<const DCPContent> dc = dynamic_pointer_cast<const DCPContent> (content);
if (dc) {
- return shared_ptr<Decoder> (new DCPDecoder (dc, log, fast));
+ try {
+ return shared_ptr<Decoder> (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<Decoder>();
+ }
}
shared_ptr<const ImageContent> ic = dynamic_pointer_cast<const ImageContent> (content);
if (ic) {
}
shared_ptr<const ImageContent> ic = dynamic_pointer_cast<const ImageContent> (content);
if (ic) {
- return shared_ptr<Decoder> (new ImageDecoder
(ic, log
));
+ return shared_ptr<Decoder> (new ImageDecoder
(film, ic
));
}
}
- shared_ptr<const
TextSubtitleContent> rc = dynamic_pointer_cast<const TextSubtit
leContent> (content);
+ shared_ptr<const
StringTextFileContent> rc = dynamic_pointer_cast<const StringTextFi
leContent> (content);
if (rc) {
if (rc) {
- return shared_ptr<Decoder> (new
TextSubtitleDecoder (
rc));
+ return shared_ptr<Decoder> (new
StringTextFileDecoder(film,
rc));
}
shared_ptr<const DCPSubtitleContent> dsc = dynamic_pointer_cast<const DCPSubtitleContent> (content);
if (dsc) {
}
shared_ptr<const DCPSubtitleContent> dsc = dynamic_pointer_cast<const DCPSubtitleContent> (content);
if (dsc) {
- return shared_ptr<Decoder> (new DCPSubtitleDecoder
(
dsc));
+ return shared_ptr<Decoder> (new DCPSubtitleDecoder
(film,
dsc));
}
shared_ptr<const VideoMXFContent> vmc = dynamic_pointer_cast<const VideoMXFContent> (content);
if (vmc) {
}
shared_ptr<const VideoMXFContent> vmc = dynamic_pointer_cast<const VideoMXFContent> (content);
if (vmc) {
- return shared_ptr<Decoder> (new VideoMXFDecoder
(vmc, log
));
+ return shared_ptr<Decoder> (new VideoMXFDecoder
(film, vmc
));
}
return shared_ptr<Decoder> ();
}
return shared_ptr<Decoder> ();