Merge branch 'master' of ssh://git.carlh.net/home/carl/git/libdcp
[libdcp.git] / src / exceptions.h
1 /*
2     Copyright (C) 2012-2018 Carl Hetherington <cth@carlh.net>
3
4     This file is part of libdcp.
5
6     libdcp is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     libdcp is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with libdcp.  If not, see <http://www.gnu.org/licenses/>.
18
19     In addition, as a special exception, the copyright holders give
20     permission to link the code of portions of this program with the
21     OpenSSL library under certain conditions as described in each
22     individual source file, and distribute linked combinations
23     including the two.
24
25     You must obey the GNU General Public License in all respects
26     for all of the code used other than OpenSSL.  If you modify
27     file(s) with this exception, you may extend this exception to your
28     version of the file(s), but you are not obligated to do so.  If you
29     do not wish to do so, delete this exception statement from your
30     version.  If you delete this exception statement from all source
31     files in the program, then also delete it here.
32 */
33
34 #ifndef LIBDCP_EXCEPTIONS_H
35 #define LIBDCP_EXCEPTIONS_H
36
37 #include <boost/filesystem.hpp>
38 #include <boost/optional.hpp>
39
40 /** @file  src/exceptions.h
41  *  @brief Exceptions thrown by libdcp.
42  */
43
44 namespace dcp
45 {
46
47 /** @class FileError
48  *  @brief An exception related to a file
49  */
50 class FileError : public std::runtime_error
51 {
52 public:
53         FileError (std::string message, boost::filesystem::path filename, int number);
54         ~FileError () throw () {}
55
56         /** @return filename of file that was involved */
57         boost::filesystem::path filename () const {
58                 return _filename;
59         }
60
61         /** @return error number of the error */
62         int number () const {
63                 return _number;
64         }
65
66 private:
67         /** filename of file that was involved */
68         boost::filesystem::path _filename;
69         int _number;
70 };
71
72 /** @class MXFFileError
73  *  @brief An exception related to an MXF file
74  */
75 class MXFFileError : public FileError
76 {
77 public:
78         MXFFileError (std::string message, boost::filesystem::path filename, int number)
79                 : FileError (message, filename, number)
80         {}
81 };
82
83 /** @class MiscError
84  *  @brief A miscellaneous exception
85  */
86 class MiscError : public std::runtime_error
87 {
88 public:
89         explicit MiscError (std::string message)
90                 : std::runtime_error (message)
91         {}
92 };
93
94 /** @class DCPReadError
95  *  @brief A DCP read exception
96  */
97 class DCPReadError : public std::runtime_error
98 {
99 public:
100         explicit DCPReadError (std::string message)
101                 : std::runtime_error(message)
102                 , _message(message)
103         {}
104
105         DCPReadError (std::string message, std::string detail);
106
107         ~DCPReadError() throw () {}
108
109         std::string message () const {
110                 return _message;
111         }
112
113         boost::optional<std::string> detail () const {
114                 return _detail;
115         }
116
117 private:
118         std::string _message;
119         boost::optional<std::string> _detail;
120 };
121
122 /** @class MissingAssetError
123  *  @brief An error of a missing asset.
124  */
125 class MissingAssetError : public DCPReadError
126 {
127 public:
128         enum AssetType {
129                 MAIN_PICTURE,  //< main picture is missing
130                 MAIN_SOUND,    //< main sound is missing
131                 MAIN_SUBTITLE, //< main subtitle is missing
132                 UNKNOWN        //< something is missing but we don't know what
133         };
134
135         MissingAssetError (boost::filesystem::path, AssetType = UNKNOWN);
136         ~MissingAssetError () throw () {}
137 };
138
139 class BadContentKindError : public DCPReadError
140 {
141 public:
142         BadContentKindError (std::string content_kind);
143 };
144
145 /** @class XMLError
146  *  @brief An XML error
147  */
148 class XMLError : public std::runtime_error
149 {
150 public:
151         explicit XMLError (std::string message)
152                 : std::runtime_error (message)
153         {}
154 };
155
156 /** @class UnresolvedRefError
157  *  @brief An exception caused by a reference (by UUID) to something which is not known
158  */
159 class UnresolvedRefError : public std::runtime_error
160 {
161 public:
162         explicit UnresolvedRefError (std::string id);
163 };
164
165 /** @class TimeFormatError
166  *  @brief A an error with a string passed to LocalTime.
167  */
168 class TimeFormatError : public std::runtime_error
169 {
170 public:
171         explicit TimeFormatError (std::string bad_time);
172 };
173
174 /** @class NotEncryptedError
175  *  @brief An error raised when creating a DecryptedKDM object for assets that are not
176  *  encrypted.
177  */
178 class NotEncryptedError : public std::runtime_error
179 {
180 public:
181         explicit NotEncryptedError (std::string const & what);
182         ~NotEncryptedError () throw () {}
183 };
184
185 /** @class ProgrammingError
186  *  @brief An exception thrown when a DCP_ASSERT fails; something that should not happen.
187  */
188 class ProgrammingError : public std::runtime_error
189 {
190 public:
191         ProgrammingError (std::string file, int line);
192 };
193
194 class MismatchedStandardError : public DCPReadError
195 {
196 public:
197         MismatchedStandardError ();
198 };
199
200 class KDMDecryptionError : public std::runtime_error
201 {
202 public:
203         KDMDecryptionError (std::string message, int cipher_length, int modulus_dmax);
204 };
205
206 class KDMFormatError : public std::runtime_error
207 {
208 public:
209         KDMFormatError (std::string message);
210 };
211
212 class CertificateChainError : public std::runtime_error
213 {
214 public:
215         CertificateChainError (std::string message);
216 };
217
218 }
219
220 #endif