Bump libcxml for comment-in-node-data fix.
[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         {}
103
104         DCPReadError (std::string message, std::string detail);
105
106         ~DCPReadError() throw () {}
107
108         std::string message () const {
109                 return _message;
110         }
111
112         boost::optional<std::string> detail () const {
113                 return _detail;
114         }
115
116 private:
117         std::string _message;
118         boost::optional<std::string> _detail;
119 };
120
121 /** @class MissingAssetError
122  *  @brief An error of a missing asset.
123  */
124 class MissingAssetError : public DCPReadError
125 {
126 public:
127         enum AssetType {
128                 MAIN_PICTURE,  //< main picture is missing
129                 MAIN_SOUND,    //< main sound is missing
130                 MAIN_SUBTITLE, //< main subtitle is missing
131                 UNKNOWN        //< something is missing but we don't know what
132         };
133
134         MissingAssetError (boost::filesystem::path, AssetType = UNKNOWN);
135         ~MissingAssetError () throw () {}
136 };
137
138 /** @class XMLError
139  *  @brief An XML error
140  */
141 class XMLError : public std::runtime_error
142 {
143 public:
144         explicit XMLError (std::string message)
145                 : std::runtime_error (message)
146         {}
147 };
148
149 /** @class UnresolvedRefError
150  *  @brief An exception caused by a reference (by UUID) to something which is not known
151  */
152 class UnresolvedRefError : public std::runtime_error
153 {
154 public:
155         explicit UnresolvedRefError (std::string id);
156 };
157
158 /** @class TimeFormatError
159  *  @brief A an error with a string passed to LocalTime.
160  */
161 class TimeFormatError : public std::runtime_error
162 {
163 public:
164         explicit TimeFormatError (std::string bad_time);
165 };
166
167 /** @class NotEncryptedError
168  *  @brief An error raised when creating a DecryptedKDM object for assets that are not
169  *  encrypted.
170  */
171 class NotEncryptedError : public std::runtime_error
172 {
173 public:
174         explicit NotEncryptedError (std::string const & what);
175         ~NotEncryptedError () throw () {}
176 };
177
178 /** @class ProgrammingError
179  *  @brief An exception thrown when a DCP_ASSERT fails; something that should not happen.
180  */
181 class ProgrammingError : public std::runtime_error
182 {
183 public:
184         ProgrammingError (std::string file, int line);
185 };
186
187 class MismatchedStandardError : public DCPReadError
188 {
189 public:
190         MismatchedStandardError ();
191 };
192
193 class KDMDecryptionError : public std::runtime_error
194 {
195 public:
196         KDMDecryptionError (std::string message, int cipher_length, int modulus_dmax);
197 };
198
199 class KDMFormatError : public std::runtime_error
200 {
201 public:
202         KDMFormatError (std::string message);
203 };
204
205 class CertificateChainError : public std::runtime_error
206 {
207 public:
208         CertificateChainError (std::string message);
209 };
210
211 }
212
213 #endif