X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_examiner.h;h=4b93bfa4298e99606f9d61f4e14923221065f268;hb=3006dde72c92356165ef841910368d0dae27ddbe;hp=aaeec6d3249c6405bee61bda579527ddbf367105;hpb=c6871fe8617b3de03662b7630355059393bf8043;p=dcpomatic.git diff --git a/src/lib/dcp_examiner.h b/src/lib/dcp_examiner.h index aaeec6d32..4b93bfa42 100644 --- a/src/lib/dcp_examiner.h +++ b/src/lib/dcp_examiner.h @@ -33,12 +33,18 @@ class DCPExaminer : public DCP, public VideoExaminer, public AudioExaminer public: explicit DCPExaminer (boost::shared_ptr); + bool has_video () const { + return _has_video; + } + boost::optional video_frame_rate () const { return _video_frame_rate; } dcp::Size video_size () const { - return _video_size.get_value_or (dcp::Size (1998, 1080)); + DCPOMATIC_ASSERT (_has_video); + DCPOMATIC_ASSERT (_video_size); + return *_video_size; } Frame video_length () const { @@ -53,10 +59,6 @@ public: return _name; } - bool has_subtitles () const { - return _has_subtitles; - } - bool encrypted () const { return _encrypted; } @@ -65,6 +67,10 @@ public: return _needs_assets; } + bool has_audio () const { + return _has_audio; + } + int audio_channels () const { return _audio_channels.get_value_or (0); } @@ -77,6 +83,10 @@ public: return _audio_frame_rate.get_value_or (48000); } + bool has_text (TextType type) const { + return _has_text[type]; + } + bool kdm_valid () const { return _kdm_valid; } @@ -105,7 +115,11 @@ private: boost::optional _audio_frame_rate; Frame _audio_length; std::string _name; - bool _has_subtitles; + /** true if this DCP has video content (but false if it has unresolved references to video content) */ + bool _has_video; + /** true if this DCP has audio content (but false if it has unresolved references to audio content) */ + bool _has_audio; + bool _has_text[TEXT_COUNT]; bool _encrypted; bool _needs_assets; bool _kdm_valid;