diff options
| author | Carl Hetherington <cth@carlh.net> | 2020-12-13 22:23:07 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2021-01-17 20:13:22 +0100 |
| commit | 9a5db0824d48bac475abbb9ff4dc1c7b5f28edab (patch) | |
| tree | e00a3fa53ca24532ecd28b04b3bc965da3370505 /src/verify.cc | |
| parent | 588463ca317c588f0dfca046cc52dfe026654527 (diff) | |
Bv2.1 7.2.1: Check size of closed caption XML is not larger than 256KB.
Diffstat (limited to 'src/verify.cc')
| -rw-r--r-- | src/verify.cc | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/verify.cc b/src/verify.cc index 78c087da..9cfcd4b9 100644 --- a/src/verify.cc +++ b/src/verify.cc @@ -663,6 +663,26 @@ verify_subtitle_asset ( } +static void +verify_closed_caption_asset ( + shared_ptr<const SubtitleAsset> asset, + function<void (string, optional<boost::filesystem::path>)> stage, + boost::filesystem::path xsd_dtd_directory, + list<VerificationNote>& notes + ) +{ + verify_subtitle_asset (asset, stage, xsd_dtd_directory, notes); + + if (asset->raw_xml().size() > 256 * 1024) { + notes.push_back ( + VerificationNote( + VerificationNote::VERIFY_BV21_ERROR, VerificationNote::CLOSED_CAPTION_XML_TOO_LARGE_IN_BYTES, *asset->file() + ) + ); + } +} + + list<VerificationNote> dcp::verify ( vector<boost::filesystem::path> directories, @@ -763,7 +783,7 @@ dcp::verify ( BOOST_FOREACH (shared_ptr<dcp::ReelClosedCaptionAsset> i, reel->closed_captions()) { verify_closed_caption_reel (i, notes); if (i->asset_ref().resolved()) { - verify_subtitle_asset (i->asset(), stage, xsd_dtd_directory, notes); + verify_closed_caption_asset (i->asset(), stage, xsd_dtd_directory, notes); } } } @@ -835,7 +855,8 @@ dcp::note_to_string (dcp::VerificationNote note) return String::compose("A picture asset's frame rate (%1) is not 24fps as required for 4K DCPs by Bv2.1", note.note().get()); case dcp::VerificationNote::PICTURE_ASSET_4K_3D: return "3D 4K DCPs are not allowed by Bv2.1"; - + case dcp::VerificationNote::CLOSED_CAPTION_XML_TOO_LARGE_IN_BYTES: + return String::compose("The XML for the closed caption asset %1 is longer than the 256KB maximum required by Bv2.1", note.file()->filename()); } return ""; |
