diff options
| author | Carl Hetherington <cth@carlh.net> | 2018-03-20 23:40:58 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2018-03-20 23:40:58 +0000 |
| commit | 03246708c1ee9c5331eac7d058627655939e30d1 (patch) | |
| tree | 877b655906ce346b63f49e52fa78e3629f6e3217 /src/verify.cc | |
| parent | 010b38e7ac7779e9a9c346361fe7e0a4fda202c8 (diff) | |
More DCP verification bits.
Diffstat (limited to 'src/verify.cc')
| -rw-r--r-- | src/verify.cc | 48 |
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; |
