X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Freel.h;h=fdbe473a64739de24ee35065579fcd1cef447b07;hb=6c37cc1979b2a01205a888c4c98f3334685ee8dd;hp=0a3cf19ae8b6a344d7d04468957bdf29f20edd47;hpb=9eba1ff84fd89e2ff04181799f2185c8575de16d;p=libdcp.git diff --git a/src/reel.h b/src/reel.h index 0a3cf19a..fdbe473a 100644 --- a/src/reel.h +++ b/src/reel.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2014 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington This file is part of libdcp. @@ -31,26 +31,31 @@ files in the program, then also delete it here. */ + #ifndef LIBDCP_REEL_H #define LIBDCP_REEL_H + #include "key.h" #include "types.h" #include "ref.h" -#include +#include #include -#include + namespace cxml { class Node; } + namespace xmlpp { class Element; } + namespace dcp { + class DecryptedKDM; class ReelAsset; class ReelPictureAsset; @@ -61,6 +66,7 @@ class ReelClosedCaptionAsset; class ReelAtmosAsset; class Content; + /** @brief A reel within a DCP; the part which actually refers to picture, sound, subtitle, marker and Atmos data */ class Reel : public Object { @@ -68,11 +74,11 @@ public: Reel () {} Reel ( - boost::shared_ptr picture, - boost::shared_ptr sound = boost::shared_ptr (), - boost::shared_ptr subtitle = boost::shared_ptr (), - boost::shared_ptr markers = boost::shared_ptr (), - boost::shared_ptr atmos = boost::shared_ptr () + std::shared_ptr picture, + std::shared_ptr sound = std::shared_ptr (), + std::shared_ptr subtitle = std::shared_ptr (), + std::shared_ptr markers = std::shared_ptr (), + std::shared_ptr atmos = std::shared_ptr () ) : _main_picture (picture) , _main_sound (sound) @@ -81,53 +87,56 @@ public: , _atmos (atmos) {} - explicit Reel (boost::shared_ptr); + explicit Reel (std::shared_ptr); - boost::shared_ptr main_picture () const { + std::shared_ptr main_picture () const { return _main_picture; } - boost::shared_ptr main_sound () const { + std::shared_ptr main_sound () const { return _main_sound; } - boost::shared_ptr main_subtitle () const { + std::shared_ptr main_subtitle () const { return _main_subtitle; } - boost::shared_ptr main_markers () const { + std::shared_ptr main_markers () const { return _main_markers; } - std::list > closed_captions () const { + std::vector> closed_captions () const { return _closed_captions; } - boost::shared_ptr atmos () const { + std::shared_ptr atmos () const { return _atmos; } int64_t duration () const; - void add (boost::shared_ptr asset); + void add (std::shared_ptr asset); + + std::vector> assets () const; - void write_to_cpl (xmlpp::Element* node, Standard standard) const; + xmlpp::Element* write_to_cpl (xmlpp::Element* node, Standard standard) const; - bool encrypted () const; + bool any_encrypted () const; + bool all_encrypted () const; - bool equals (boost::shared_ptr other, EqualityOptions opt, NoteHandler notes) const; + bool equals (std::shared_ptr other, EqualityOptions opt, NoteHandler notes) const; void add (DecryptedKDM const &); - void resolve_refs (std::list >); + void resolve_refs (std::vector>); private: - boost::shared_ptr _main_picture; - boost::shared_ptr _main_sound; - boost::shared_ptr _main_subtitle; - boost::shared_ptr _main_markers; - std::list > _closed_captions; - boost::shared_ptr _atmos; + std::shared_ptr _main_picture; + std::shared_ptr _main_sound; + std::shared_ptr _main_subtitle; + std::shared_ptr _main_markers; + std::vector> _closed_captions; + std::shared_ptr _atmos; }; }