summaryrefslogtreecommitdiff
path: root/src/verify.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-03-20 23:40:58 +0000
committerCarl Hetherington <cth@carlh.net>2018-03-20 23:40:58 +0000
commit03246708c1ee9c5331eac7d058627655939e30d1 (patch)
tree877b655906ce346b63f49e52fa78e3629f6e3217 /src/verify.cc
parent010b38e7ac7779e9a9c346361fe7e0a4fda202c8 (diff)
More DCP verification bits.
Diffstat (limited to 'src/verify.cc')
-rw-r--r--src/verify.cc48
1 files changed, 45 insertions, 3 deletions
diff --git a/src/verify.cc b/src/verify.cc
index 8f850e83..75cab01d 100644
--- a/src/verify.cc
+++ b/src/verify.cc
@@ -33,19 +33,37 @@
#include "verify.h"
#include "dcp.h"
+#include "cpl.h"
+#include "reel.h"
+#include "reel_picture_asset.h"
+#include "reel_sound_asset.h"
#include "exceptions.h"
#include <boost/foreach.hpp>
#include <list>
#include <vector>
+#include <iostream>
using std::list;
using std::vector;
+using std::string;
+using std::cout;
using boost::shared_ptr;
+using boost::optional;
+using boost::function;
using namespace dcp;
+static bool
+verify_asset (shared_ptr<ReelAsset> asset, function<void (float)> progress)
+{
+ string actual_hash = asset->asset_ref()->hash(progress);
+ optional<string> cpl_hash = asset->hash();
+ DCP_ASSERT (cpl_hash);
+ return actual_hash != *cpl_hash;
+}
+
list<VerificationNote>
-dcp::verify (vector<boost::filesystem::path> directories)
+dcp::verify (vector<boost::filesystem::path> directories, function<void (string, optional<boost::filesystem::path>)> stage, function<void (float)> progress)
{
list<VerificationNote> notes;
@@ -54,15 +72,39 @@ dcp::verify (vector<boost::filesystem::path> directories)
dcps.push_back (shared_ptr<DCP> (new DCP (i)));
}
- BOOST_FOREACH (shared_ptr<DCP> i, dcps) {
+ BOOST_FOREACH (shared_ptr<DCP> dcp, dcps) {
+ stage ("Checking DCP", dcp->directory());
DCP::ReadErrors errors;
try {
- i->read (true, &errors);
+ dcp->read (true, &errors);
} catch (DCPReadError& e) {
notes.push_back (VerificationNote (VerificationNote::VERIFY_ERROR, e.what ()));
} catch (XMLError& e) {
notes.push_back (VerificationNote (VerificationNote::VERIFY_ERROR, e.what ()));
}
+
+ BOOST_FOREACH (shared_ptr<CPL> cpl, dcp->cpls()) {
+ stage ("Checking CPL", cpl->file());
+ BOOST_FOREACH (shared_ptr<Reel> reel, cpl->reels()) {
+ stage ("Checking reel", optional<boost::filesystem::path>());
+ if (reel->main_picture()) {
+ stage ("Checking picture asset hash", reel->main_picture()->asset()->file());
+ if (verify_asset (reel->main_picture(), progress)) {
+ notes.push_back (VerificationNote (VerificationNote::VERIFY_ERROR, "Picture asset hash is incorrect"));
+ } else {
+ cout << "pic ok.\n";
+ }
+ }
+ if (reel->main_sound()) {
+ stage ("Checking sound asset hash", reel->main_sound()->asset()->file());
+ if (verify_asset (reel->main_sound(), progress)) {
+ notes.push_back (VerificationNote (VerificationNote::VERIFY_ERROR, "Sound asset hash is incorrect"));
+ } else {
+ cout << "sounds ok.\n";
+ }
+ }
+ }
+ }
}
return notes;