X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_examiner.h;h=ac43805977c98f75d5cc9eea1a0c6e94a8871c64;hb=8b9888ed8247109dc3c09492302e865fa4731460;hp=3fedaca06aded36f75f4beacd85de8ef2fd954ee;hpb=8fedaaa75c4586a4cc7ffb393bd71d1fdb091dc8;p=dcpomatic.git diff --git a/src/lib/dcp_examiner.h b/src/lib/dcp_examiner.h index 3fedaca06..ac4380597 100644 --- a/src/lib/dcp_examiner.h +++ b/src/lib/dcp_examiner.h @@ -18,50 +18,58 @@ */ + /** @file src/lib/dcp_examiner.h * @brief DCPExaminer class. */ -#include "video_examiner.h" + #include "audio_examiner.h" -#include "dcp.h" #include "dcp_text_track.h" #include "dcpomatic_assert.h" +#include "video_examiner.h" #include +#include + class DCPContent; -class DCPExaminer : public DCP, public VideoExaminer, public AudioExaminer + +class DCPExaminer : public VideoExaminer, public AudioExaminer { public: explicit DCPExaminer (std::shared_ptr, bool tolerant); - bool has_video () const { + bool has_video () const override { return _has_video; } - boost::optional video_frame_rate () const { + boost::optional video_frame_rate () const override { return _video_frame_rate; } - dcp::Size video_size () const { + dcp::Size video_size () const override { DCPOMATIC_ASSERT (_has_video); DCPOMATIC_ASSERT (_video_size); return *_video_size; } - Frame video_length () const { + Frame video_length () const override { return _video_length; } - bool yuv () const { + bool yuv () const override { return false; } - VideoRange range () const { + VideoRange range () const override { return VideoRange::FULL; } + PixelQuanta pixel_quanta () const override { + return {}; + } + std::string name () const { return _name; } @@ -74,22 +82,26 @@ public: return _needs_assets; } - bool has_audio () const { + bool has_audio () const override { return _has_audio; } - int audio_channels () const { + int audio_channels () const override { return _audio_channels.get_value_or (0); } - Frame audio_length () const { + Frame audio_length () const override { return _audio_length; } - int audio_frame_rate () const { + int audio_frame_rate () const override { return _audio_frame_rate.get_value_or (48000); } + boost::optional audio_language () const { + return _audio_language; + } + /** @param type TEXT_OPEN_SUBTITLE or TEXT_CLOSED_CAPTION. * @return Number of assets of this type in this DCP. */ @@ -97,6 +109,10 @@ public: return _text_count[static_cast(type)]; } + boost::optional open_subtitle_language () const { + return _open_subtitle_language; + } + DCPTextTrack dcp_text_track (int i) const { DCPOMATIC_ASSERT (i >= 0 && i < static_cast(_dcp_text_tracks.size())); return _dcp_text_tracks[i]; @@ -150,6 +166,11 @@ public: return _atmos_edit_rate; } + /** @return fonts in each reel */ + std::vector>> fonts() const { + return _fonts; + } + private: boost::optional _video_frame_rate; boost::optional _video_size; @@ -162,8 +183,10 @@ private: bool _has_video = false; /** true if this DCP has audio content (but false if it has unresolved references to audio content) */ bool _has_audio = false; + boost::optional _audio_language; /** number of different assets of each type (OCAP/CCAP) */ int _text_count[static_cast(TextType::COUNT)]; + boost::optional _open_subtitle_language; /** the DCPTextTracks for each of our CCAPs */ std::vector _dcp_text_tracks; bool _encrypted = false; @@ -180,4 +203,5 @@ private: bool _has_atmos = false; Frame _atmos_length = 0; dcp::Fraction _atmos_edit_rate; + std::vector>> _fonts; };