diff options
| author | Carl Hetherington <cth@carlh.net> | 2015-10-19 23:30:04 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2015-10-19 23:30:04 +0100 |
| commit | 6ea37804a7f9dd72a29a25e7594a39fa47f53192 (patch) | |
| tree | b78bfdc3ef2ba3d61dfb3ce0930f741ec92548a3 /src/exceptions.cc | |
| parent | f6b789850b0cd50971707084632c4ec08e145d0f (diff) | |
Use std::runtime_error instead of our own StringError as
a) it does the same job and
b) its type and what() survive the boundary between the libdcp .so
and the main DCP-o-matic executable.
Before this StringError-derived exceptions caught by DCP-o-matic
were only recognised as std::exceptions (without the what()) message.
I don't know why this happens, but this works around it.
Diffstat (limited to 'src/exceptions.cc')
| -rw-r--r-- | src/exceptions.cc | 35 |
1 files changed, 12 insertions, 23 deletions
diff --git a/src/exceptions.cc b/src/exceptions.cc index e1eaa52e..c588696e 100644 --- a/src/exceptions.cc +++ b/src/exceptions.cc @@ -25,10 +25,11 @@ #include "compose.hpp" using std::string; +using std::runtime_error; using namespace dcp; FileError::FileError (string message, boost::filesystem::path filename, int number) - : StringError (String::compose ("%1 (%2) (error %3)", message, filename.string(), number)) + : runtime_error (String::compose ("%1 (%2) (error %3)", message, filename.string(), number)) , _filename (filename) , _number (number) { @@ -36,48 +37,36 @@ FileError::FileError (string message, boost::filesystem::path filename, int numb } UnresolvedRefError::UnresolvedRefError (string id) - : StringError (String::compose ("Unresolved reference to asset id %1", id)) + : runtime_error (String::compose ("Unresolved reference to asset id %1", id)) { } TimeFormatError::TimeFormatError (string bad_time) - : StringError (String::compose ("Bad time string %1", bad_time)) + : runtime_error (String::compose ("Bad time string %1", bad_time)) { } MissingAssetError::MissingAssetError (boost::filesystem::path path, AssetType type) - : _path (path) - , _type (type) + : DCPReadError ( + type == MAIN_PICTURE ? String::compose ("missing asset %1 for main picture", path.string()) : + (type == MAIN_SOUND ? String::compose ("missing asset %1 for main sound", path.string()) : + (type == MAIN_SUBTITLE ? String::compose ("missing asset %1 for main subtitle", path.string()) : + String::compose ("missing asset %1", path.string())))) { - string type_name; - switch (_type) { - case MAIN_PICTURE: - type_name = " for main picture"; - break; - case MAIN_SOUND: - type_name = " for main sound"; - break; - case MAIN_SUBTITLE: - type_name = " for main subtitle"; - break; - case UNKNOWN: - break; - } - - _message = String::compose ("Missing asset %1%2", path.string(), type_name); + } NotEncryptedError::NotEncryptedError (string const & what) - : StringError (String::compose ("%1 is not encrypted", what)) + : runtime_error (String::compose ("%1 is not encrypted", what)) { } ProgrammingError::ProgrammingError (string file, int line) - : StringError (String::compose ("Programming error at %1:%2", file, line)) + : runtime_error (String::compose ("Programming error at %1:%2", file, line)) { } |
