From 7acc2f5d8edc157c206012cb83167845ec7d09c7 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Mon, 13 Jun 2016 23:12:18 +0100 Subject: [PATCH] Improve error messages on failing to load DCP subs. --- ChangeLog | 4 ++++ cscript | 2 +- src/lib/dcp_subtitle.cc | 15 ++++++++++----- 3 files changed, 15 insertions(+), 6 deletions(-) diff --git a/ChangeLog b/ChangeLog index 44b857dfc..c57730218 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2016-06-13 Carl Hetherington + + * Give better error messages when subtitles fail to load. + 2016-06-13 c.hetherington * Add button to move things to the start of reels (#798). diff --git a/cscript b/cscript index 260c0f2ec..82c39a0f8 100644 --- a/cscript +++ b/cscript @@ -237,7 +237,7 @@ def dependencies(target): ffmpeg_options = {} return (('ffmpeg-cdist', 'aab2fb1', ffmpeg_options), - ('libdcp', 'd927e9b'), + ('libdcp', '937e435'), ('libsub', '3e299e5')) def configure_options(target): diff --git a/src/lib/dcp_subtitle.cc b/src/lib/dcp_subtitle.cc index b0e114be2..f9aa7e0d9 100644 --- a/src/lib/dcp_subtitle.cc +++ b/src/lib/dcp_subtitle.cc @@ -20,34 +20,39 @@ #include "dcp_subtitle.h" #include "exceptions.h" +#include "compose.hpp" #include #include #include "i18n.h" +using std::string; +using std::exception; using boost::shared_ptr; shared_ptr DCPSubtitle::load (boost::filesystem::path file) const { shared_ptr sc; + string interop_error; + string smpte_error; try { sc.reset (new dcp::InteropSubtitleAsset (file)); - } catch (...) { - + } catch (exception& e) { + interop_error = e.what (); } if (!sc) { try { sc.reset (new dcp::SMPTESubtitleAsset (file)); - } catch (...) { - + } catch (exception& e) { + smpte_error = e.what(); } } if (!sc) { - throw FileError (_("Could not read subtitles"), file); + throw FileError (String::compose (_("Could not read subtitles (%1 / %2)"), interop_error, smpte_error), file); } return sc; -- 2.30.2