X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fcpl.h;h=75b9d701c7ee5ae6cf14bf238cf3c2a520cca274;hb=113187d5d1e7e5a079eb26f99b31e687d503cc07;hp=aadc73478da7f6c4221edd1fa293934eb666963b;hpb=f8005516a681b805ccc2d929f63312ac711fdc24;p=libdcp.git diff --git a/src/cpl.h b/src/cpl.h index aadc7347..75b9d701 100644 --- a/src/cpl.h +++ b/src/cpl.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2014 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -20,45 +20,65 @@ #ifndef LIBDCP_CPL_H #define LIBDCP_CPL_H -#include +#include "types.h" +#include "certificates.h" +#include "key.h" +#include "asset.h" +#include "metadata.h" +#include #include #include -#include #include #include -#include -#include "types.h" -#include "certificates.h" -#include "key.h" - -namespace libdcp { +#include -namespace parse { - class AssetMap; - class AssetMapAsset; -} +namespace dcp { -class Asset; +class Content; class Reel; class XMLMetadata; class MXFMetadata; class Signer; -class KDM; +class DecryptedKDM; -/** @brief A CPL within a DCP */ -class CPL +/** @class CPL + * @brief A Composition Playlist. + */ +class CPL : public Asset { public: - CPL (boost::filesystem::path directory, std::string name, ContentKind content_kind, int length, int frames_per_second); - CPL (boost::filesystem::path, std::string file, std::list asset_maps, bool require_mxfs = true); + CPL (std::string annotation_text, ContentKind content_kind); + CPL (boost::filesystem::path file); + + bool equals ( + CPL const & other, + EqualityOptions options, + boost::function note + ) const; - void add_reel (boost::shared_ptr reel); + void add (boost::shared_ptr reel); + void add (DecryptedKDM const &); + + /** @return contents of the <AnnotationText> node */ + std::string annotation_text () const { + return _annotation_text; + } - /** @return the length in frames */ - int length () const { - return _length; + /** @return contents of the <ContentTitleText> node */ + std::string content_title_text () const { + return _content_title_text; + } + + /** @return contents of the <Id> node within <ContentVersion> */ + void set_content_version_id (std::string id) { + _content_version_id = id; } + /** @return contents of the <LabelText> node within <ContentVersion> */ + void set_content_version_label_text (std::string text) { + _content_version_label_text = text; + } + /** @return the type of the content, used by media servers * to categorise things (e.g. feature, trailer, etc.) */ @@ -66,59 +86,46 @@ public: return _content_kind; } + /** @return the reels in this CPL */ std::list > reels () const { return _reels; } - /** @return the CPL's name, as will be presented on projector - * media servers and theatre management systems. + /** @return the Content in this CPL across all its reels + * (Content is picture, sound and subtitles) */ - std::string name () const { - return _name; - } - - /** @return the number of frames per second */ - int frames_per_second () const { - return _fps; - } - - std::list > assets () const; + std::list > content () const; bool encrypted () const; void set_mxf_keys (Key); - - std::string id () const { - return _id; + void set_metadata (XMLMetadata m) { + _metadata = m; } - - bool equals (CPL const & other, EqualityOptions options, boost::function note) const; - - void write_xml (bool, XMLMetadata const &, boost::shared_ptr) const; - void write_to_assetmap (xmlpp::Node *) const; - void write_to_pkl (xmlpp::Node *) const; - void add_kdm (KDM const &); - + void write_xml ( + boost::filesystem::path file, + Standard standard, + boost::shared_ptr + ) const; + + void resolve_refs (std::list >); + +protected: + /** @return type string for PKLs for this asset */ + std::string pkl_type (Standard standard) const; + private: - std::pair > asset_from_id (std::list, std::string id) const; - - boost::filesystem::path _directory; - /** the name of the DCP */ - std::string _name; - /** the content kind of the CPL */ - ContentKind _content_kind; - /** length in frames */ - mutable int _length; - /** frames per second */ - int _fps; - /** reels */ + std::string _annotation_text; ///< <AnnotationText> + /** <Issuer>, <Creator> and <IssueDate>. These are grouped + * because they occur together in a few places. + */ + XMLMetadata _metadata; + std::string _content_title_text; ///< <ContentTitleText> + ContentKind _content_kind; ///< <ContentKind> + std::string _content_version_id; ///< <Id> in <ContentVersion> + std::string _content_version_label_text; ///< <LabelText> in <ContentVersion> std::list > _reels; - - /** our UUID */ - std::string _id; - /** a SHA1 digest of our XML */ - mutable std::string _digest; }; }