Move verify API away from strings towards error codes.
[libdcp.git] / src / verify.h
1 /*
2     Copyright (C) 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_VERIFY_H
35 #define LIBDCP_VERIFY_H
36
37 #include <boost/filesystem.hpp>
38 #include <boost/function.hpp>
39 #include <boost/optional.hpp>
40 #include <string>
41 #include <list>
42 #include <vector>
43
44 namespace dcp {
45
46 class VerificationNote
47 {
48 public:
49         /* I've been unable to make mingw happy with ERROR as a symbol, so
50            I'm using a VERIFY_ prefix here.
51         */
52         enum Type {
53                 VERIFY_ERROR,
54                 VERIFY_WARNING
55         };
56
57         enum Code {
58                 /** An error when reading the DCP.  note contains (probably technical) details. */
59                 GENERAL_READ,
60                 /** The hash of the CPL in the PKL does not agree with the CPL file */
61                 CPL_HASH_INCORRECT,
62                 /** Frame rate given in a reel for the main picture is not 24, 25, 30, 48, 50 or 60 */
63                 INVALID_PICTURE_FRAME_RATE,
64                 /** The hash of a main picture asset does not agree with the PKL file.  file contains the picture asset filename. */
65                 PICTURE_HASH_INCORRECT,
66                 /** The hash of a main picture is different in the CPL and PKL */
67                 PKL_CPL_PICTURE_HASHES_DISAGREE,
68                 /** The hash of a main sound asset does not agree with the PKL file.  file contains the sound asset filename. */
69                 SOUND_HASH_INCORRECT,
70                 /** The hash of a main sound is different in the CPL and PKL */
71                 PKL_CPL_SOUND_HASHES_DISAGREE,
72         };
73
74         VerificationNote (Type type, Code code)
75                 : _type (type)
76                 , _code (code)
77         {}
78
79         VerificationNote (Type type, Code code, std::string note)
80                 : _type (type)
81                 , _code (code)
82                 , _note (note)
83         {}
84
85         VerificationNote (Type type, Code code, boost::filesystem::path file)
86                 : _type (type)
87                 , _code (code)
88                 , _file (file)
89         {}
90
91         Type type () const {
92                 return _type;
93         }
94
95         Code code () const {
96                 return _code;
97         }
98
99         boost::optional<std::string> note () const {
100                 return _note;
101         }
102
103         boost::optional<boost::filesystem::path> file () const {
104                 return _file;
105         }
106
107 private:
108         Type _type;
109         Code _code;
110         boost::optional<std::string> _note;
111         boost::optional<boost::filesystem::path> _file;
112 };
113
114 std::list<VerificationNote> verify (
115         std::vector<boost::filesystem::path> directories,
116         boost::function<void (std::string, boost::optional<boost::filesystem::path>)> stage,
117         boost::function<void (float)> progress
118         );
119
120 }
121
122 #endif