diff options
| author | Carl Hetherington <cth@carlh.net> | 2016-06-13 23:12:18 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2016-06-13 23:12:18 +0100 |
| commit | 7acc2f5d8edc157c206012cb83167845ec7d09c7 (patch) | |
| tree | a90d961537bdf08b062e805af2d1aa3852e98ea9 | |
| parent | 13aae5d8ff27886656ab7ea3ef1194987954bb3f (diff) | |
Improve error messages on failing to load DCP subs.
| -rw-r--r-- | ChangeLog | 4 | ||||
| -rw-r--r-- | cscript | 2 | ||||
| -rw-r--r-- | src/lib/dcp_subtitle.cc | 15 |
3 files changed, 15 insertions, 6 deletions
@@ -1,3 +1,7 @@ +2016-06-13 Carl Hetherington <cth@carlh.net> + + * Give better error messages when subtitles fail to load. + 2016-06-13 c.hetherington <cth@carlh.net> * Add button to move things to the start of reels (#798). @@ -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 <dcp/interop_subtitle_asset.h> #include <dcp/smpte_subtitle_asset.h> #include "i18n.h" +using std::string; +using std::exception; using boost::shared_ptr; shared_ptr<dcp::SubtitleAsset> DCPSubtitle::load (boost::filesystem::path file) const { shared_ptr<dcp::SubtitleAsset> 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; |
