X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_examiner.h;h=f577e2b3552c999a1f5f0b3e681fbafe4c785248;hb=9b946fc5250eff5a5dd4a661896916fcd5d9bd4b;hp=21aa8d3ab58537de5c4446f899f94d4bcc4bb459;hpb=5f3a88d3ab1e9c1a13d7e61fc37a0c4cef8df9a5;p=dcpomatic.git diff --git a/src/lib/dcp_examiner.h b/src/lib/dcp_examiner.h index 21aa8d3ab..f577e2b35 100644 --- a/src/lib/dcp_examiner.h +++ b/src/lib/dcp_examiner.h @@ -25,6 +25,8 @@ #include "video_examiner.h" #include "audio_examiner.h" #include "dcp.h" +#include "dcp_text_track.h" +#include "dcpomatic_assert.h" #include class DCPContent; @@ -32,7 +34,7 @@ class DCPContent; class DCPExaminer : public DCP, public VideoExaminer, public AudioExaminer { public: - explicit DCPExaminer (boost::shared_ptr, bool tolerant); + explicit DCPExaminer (std::shared_ptr, bool tolerant); bool has_video () const { return _has_video; @@ -95,6 +97,11 @@ public: return _text_count[type]; } + DCPTextTrack dcp_text_track (int i) const { + DCPOMATIC_ASSERT (i >= 0 && i < static_cast(_dcp_text_tracks.size())); + return _dcp_text_tracks[i]; + } + bool kdm_valid () const { return _kdm_valid; } @@ -127,8 +134,20 @@ public: return _ratings; } - std::string content_version () const { - return _content_version; + std::vector content_versions () const { + return _content_versions; + } + + bool has_atmos () const { + return _has_atmos; + } + + Frame atmos_length () const { + return _atmos_length; + } + + dcp::Fraction atmos_edit_rate () const { + return _atmos_edit_rate; } private: @@ -145,6 +164,8 @@ private: bool _has_audio; /** number of different assets of each type (OCAP/CCAP) */ int _text_count[TEXT_COUNT]; + /** the DCPTextTracks for each of our CCAPs */ + std::vector _dcp_text_tracks; bool _encrypted; bool _needs_assets; bool _kdm_valid; @@ -155,5 +176,8 @@ private: std::list _reel_lengths; std::map _markers; std::vector _ratings; - std::string _content_version; + std::vector _content_versions; + bool _has_atmos; + Frame _atmos_length; + dcp::Fraction _atmos_edit_rate; };