diff options
| author | Carl Hetherington <cth@carlh.net> | 2014-06-13 16:11:51 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2014-06-13 16:11:51 +0100 |
| commit | b7d81e736dc35325e98c558067c157b000b856c1 (patch) | |
| tree | cd8230bb2d671592e36e6dce6643cfe6c1e3231a /src/exceptions.h | |
| parent | 7bca4c05ca38b218c252b0fe98a866806d9a2ded (diff) | |
Throw NotEncryptedError on trying to make a KDM for non-encrypted assets.
Diffstat (limited to 'src/exceptions.h')
| -rw-r--r-- | src/exceptions.h | 104 |
1 files changed, 41 insertions, 63 deletions
diff --git a/src/exceptions.h b/src/exceptions.h index 5d8000d7..be87c40b 100644 --- a/src/exceptions.h +++ b/src/exceptions.h @@ -29,20 +29,34 @@ namespace dcp { +class StringError : public std::exception +{ +public: + StringError () {} + StringError (std::string message) + : _message (message) + {} + + ~StringError () throw () {} + + /** @return error message */ + char const * what () const throw () { + return _message.c_str (); + } + +protected: + std::string _message; +}; + /** @class FileError * @brief An exception related to a file */ -class FileError : public std::exception +class FileError : public StringError { public: FileError (std::string message, boost::filesystem::path filename, int number); ~FileError () throw () {} - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - /** @return filename of file that was involved */ boost::filesystem::path filename () const { return _filename; @@ -54,8 +68,6 @@ public: } private: - /** message part */ - std::string _message; /** filename of file that was involved */ boost::filesystem::path _filename; int _number; @@ -75,41 +87,26 @@ public: /** @class MiscError * @brief A miscellaneous exception */ -class MiscError : public std::exception +class MiscError : public StringError { public: - MiscError (std::string message) : _message (message) {} - ~MiscError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - /** error message */ - std::string _message; + MiscError (std::string message) + : StringError (message) + {} }; /** @class DCPReadError * @brief A DCP read exception */ -class DCPReadError : public std::exception +class DCPReadError : public StringError { public: - DCPReadError (std::string message) : _message (message) {} - ~DCPReadError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } + DCPReadError (std::string message) + : StringError (message) + {} protected: DCPReadError () {} - - /** error message */ - std::string _message; }; /** @class MissingAssetError @@ -136,58 +133,39 @@ private: /** @class XMLError * @brief An XML error */ -class XMLError : public std::exception +class XMLError : public StringError { public: - XMLError (std::string message) : _message (message) {} - ~XMLError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - /** error message */ - std::string _message; + XMLError (std::string message) + : StringError (message) + {} }; /** @class UnresolvedRefError * @brief An exception caused by a reference (by UUID) to something which is not known */ -class UnresolvedRefError : public std::exception +class UnresolvedRefError : public StringError { public: UnresolvedRefError (std::string id); - ~UnresolvedRefError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - std::string _message; }; /** @class TimeFormatError * @brief A an error with a string passed to LocalTime. */ -class TimeFormatError : public std::exception +class TimeFormatError : public StringError { public: TimeFormatError (std::string bad_time); - ~TimeFormatError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - std::string _message; }; +class NotEncryptedError : public StringError +{ +public: + NotEncryptedError (std::string const & asset_filename); + ~NotEncryptedError () throw () {} +}; + } #endif |
