summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--src/lib/ffmpeg_image_proxy.cc15
2 files changed, 18 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index f03f82d95..15987ce9e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2019-03-01 Carl Hetherington <cth@carlh.net>
+
+ * Fix loading of targa files (#1478).
+
2019-02-28 Carl Hetherington <cth@carlh.net>
* Updated cs_CZ translation from Tomáš Begeni.
diff --git a/src/lib/ffmpeg_image_proxy.cc b/src/lib/ffmpeg_image_proxy.cc
index 46c9836e0..87925dabc 100644
--- a/src/lib/ffmpeg_image_proxy.cc
+++ b/src/lib/ffmpeg_image_proxy.cc
@@ -135,7 +135,20 @@ FFmpegImageProxy::image (optional<dcp::Size>) const
int e = avformat_open_input (&format_context, 0, 0, &options);
if (e < 0) {
- throw OpenFileError (_path->string(), e, true);
+ if (e == AVERROR_INVALIDDATA) {
+ /* Hack to fix loading of .tga files through AVIOContexts (rather then
+ directly from the file). This code just does enough to allow the
+ probe code to take a hint from "foo.tga" and so try targa format.
+ */
+ AVInputFormat* f = av_find_input_format ("image2");
+ format_context = avformat_alloc_context ();
+ format_context->pb = avio_context;
+ format_context->iformat = f;
+ e = avformat_open_input (&format_context, "foo.tga", f, &options);
+ }
+ if (e < 0) {
+ throw OpenFileError (_path->string(), e, true);
+ }
}
if (avformat_find_stream_info(format_context, 0) < 0) {