X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fexceptions.h;h=99e55b2878ab1cd784da76d47c963f31427ad0e7;hb=6518f7e4e8b02a1d78b6121c2032fa27c50ddc78;hp=770bd916105998e3cf708ec34350ce59edf41da7;hpb=314060f975dc9806f49ec8bbb1c11041a2ac111f;p=libdcp.git diff --git a/src/exceptions.h b/src/exceptions.h index 770bd916..99e55b28 100644 --- a/src/exceptions.h +++ b/src/exceptions.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2019 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington This file is part of libdcp. @@ -31,19 +31,24 @@ files in the program, then also delete it here. */ + +/** @file src/exceptions.h + * @brief Exceptions thrown by libdcp + */ + + #ifndef LIBDCP_EXCEPTIONS_H #define LIBDCP_EXCEPTIONS_H + #include #include -/** @file src/exceptions.h - * @brief Exceptions thrown by libdcp. - */ namespace dcp { + /** @class FileError * @brief An exception related to a file */ @@ -69,6 +74,7 @@ private: int _number; }; + /** @class MXFFileError * @brief An exception related to an MXF file */ @@ -80,6 +86,7 @@ public: {} }; + /** @class MiscError * @brief A miscellaneous exception */ @@ -91,20 +98,21 @@ public: {} }; -/** @class DCPReadError - * @brief A DCP read exception + +/** @class ReadError + * @brief Any error that occurs when reading data from a DCP */ -class DCPReadError : public std::runtime_error +class ReadError : public std::runtime_error { public: - explicit DCPReadError (std::string message) + explicit ReadError (std::string message) : std::runtime_error(message) , _message(message) {} - DCPReadError (std::string message, std::string detail); + ReadError (std::string message, std::string detail); - ~DCPReadError() throw () {} + ~ReadError() throw () {} std::string message () const { return _message; @@ -119,12 +127,36 @@ private: boost::optional _detail; }; -class BadContentKindError : public DCPReadError + +/** @class J2KDecompressionError + * @brief An error that occurs during decompression of JPEG2000 data + */ +class J2KDecompressionError : public ReadError +{ +public: + explicit J2KDecompressionError (std::string message) + : ReadError (message) + {} +}; + + +class BadContentKindError : public ReadError { public: BadContentKindError (std::string content_kind); }; + +/** @class MissingAssetmapError + * @brief Thrown when no ASSETMAP was found when trying to read a DCP + */ +class MissingAssetmapError : public ReadError +{ +public: + explicit MissingAssetmapError (boost::filesystem::path dir); +}; + + /** @class XMLError * @brief An XML error */ @@ -136,6 +168,7 @@ public: {} }; + /** @class UnresolvedRefError * @brief An exception caused by a reference (by UUID) to something which is not known */ @@ -145,8 +178,9 @@ public: explicit UnresolvedRefError (std::string id); }; + /** @class TimeFormatError - * @brief A an error with a string passed to LocalTime. + * @brief A an error with a string passed to LocalTime */ class TimeFormatError : public std::runtime_error { @@ -154,9 +188,10 @@ public: explicit TimeFormatError (std::string bad_time); }; + /** @class NotEncryptedError * @brief An error raised when creating a DecryptedKDM object for assets that are not - * encrypted. + * encrypted */ class NotEncryptedError : public std::runtime_error { @@ -165,8 +200,9 @@ public: ~NotEncryptedError () throw () {} }; + /** @class ProgrammingError - * @brief An exception thrown when a DCP_ASSERT fails; something that should not happen. + * @brief An exception thrown when a DCP_ASSERT fails; something that should not happen */ class ProgrammingError : public std::runtime_error { @@ -174,30 +210,35 @@ public: ProgrammingError (std::string file, int line); }; + class KDMDecryptionError : public std::runtime_error { public: KDMDecryptionError (std::string message, int cipher_length, int modulus_dmax); }; + class KDMFormatError : public std::runtime_error { public: KDMFormatError (std::string message); }; + class CertificateChainError : public std::runtime_error { public: CertificateChainError (std::string message); }; + class MissingSubtitleImageError : public std::runtime_error { public: MissingSubtitleImageError (std::string id); }; + class BadKDMDateError : public std::runtime_error { public: @@ -216,6 +257,7 @@ class StartCompressionError : public std::runtime_error { public: explicit StartCompressionError (boost::optional code = boost::optional()); + ~StartCompressionError () throw () {} boost::optional code () const { return _code; @@ -225,6 +267,63 @@ private: boost::optional _code; }; + +class CombineError : public std::runtime_error +{ +public: + explicit CombineError (std::string message); +}; + + +class LanguageTagError : public std::runtime_error +{ +public: + LanguageTagError (std::string message); +}; + + +class BadSettingError : public std::runtime_error +{ +public: + BadSettingError (std::string message); +}; + + +class DuplicateIdError : public std::runtime_error +{ +public: + DuplicateIdError (std::string message); +}; + + +class MainSoundConfigurationError : public std::runtime_error +{ +public: + MainSoundConfigurationError (std::string s); +}; + + +class UnknownChannelIdError : public std::runtime_error +{ +public: + UnknownChannelIdError (std::string s); +}; + + +class NoReelsError : public std::runtime_error +{ +public: + NoReelsError (); +}; + + +class InconsistentValidityPeriodError : public std::runtime_error +{ +public: + InconsistentValidityPeriodError(); +}; + } + #endif