From 9cba0f20f339deb18c921fb799d250314745bfa9 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 1 Mar 2019 23:45:12 +0000 Subject: Fix loading of targa image files (#1478). --- ChangeLog | 4 ++++ src/lib/ffmpeg_image_proxy.cc | 15 ++++++++++++++- 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index f03f82d95..15987ce9e 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2019-03-01 Carl Hetherington + + * Fix loading of targa files (#1478). + 2019-02-28 Carl Hetherington * 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) 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) { -- cgit v1.2.3