X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_examiner.h;h=e52234e360fde46d827c6238abc6407c25810b3b;hb=1679c3dc40262733f46dda9f4151367bf93f2b76;hp=708d2e0ad167bbeae78dddda6b0d896463626898;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05;p=dcpomatic.git diff --git a/src/lib/dcp_examiner.h b/src/lib/dcp_examiner.h index 708d2e0ad..e52234e36 100644 --- a/src/lib/dcp_examiner.h +++ b/src/lib/dcp_examiner.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2019 Carl Hetherington This file is part of DCP-o-matic. @@ -24,20 +24,27 @@ #include "video_examiner.h" #include "audio_examiner.h" +#include "dcp.h" class DCPContent; -class DCPExaminer : public VideoExaminer, public AudioExaminer +class DCPExaminer : public DCP, public VideoExaminer, public AudioExaminer { public: - DCPExaminer (boost::shared_ptr); + explicit DCPExaminer (boost::shared_ptr, bool tolerant); + + 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 { @@ -48,18 +55,26 @@ public: return false; } - std::string name () const { - return _name; + VideoRange range () const { + return VIDEO_RANGE_FULL; } - bool has_subtitles () const { - return _has_subtitles; + std::string name () const { + return _name; } bool encrypted () const { return _encrypted; } + bool needs_assets () const { + return _needs_assets; + } + + bool has_audio () const { + return _has_audio; + } + int audio_channels () const { return _audio_channels.get_value_or (0); } @@ -72,6 +87,13 @@ public: return _audio_frame_rate.get_value_or (48000); } + /** @param type TEXT_OPEN_SUBTITLE or TEXT_CLOSED_CAPTION. + * @return Number of assets of this type in this DCP. + */ + int text_count (TextType type) const { + return _text_count[type]; + } + bool kdm_valid () const { return _kdm_valid; } @@ -80,6 +102,22 @@ public: return _standard; } + bool three_d () const { + return _three_d; + } + + dcp::ContentKind content_kind () const { + return _content_kind; + } + + std::string cpl () const { + return _cpl; + } + + std::list reel_lengths () const { + return _reel_lengths; + } + private: boost::optional _video_frame_rate; boost::optional _video_size; @@ -88,8 +126,18 @@ 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; + /** number of different assets of each type (OCAP/CCAP) */ + int _text_count[TEXT_COUNT]; bool _encrypted; + bool _needs_assets; bool _kdm_valid; boost::optional _standard; + bool _three_d; + dcp::ContentKind _content_kind; + std::string _cpl; + std::list _reel_lengths; };