/* 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 the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef LIBDCP_REEL_ASSET_H #define LIBDCP_REEL_ASSET_H #include "object.h" #include "util.h" #include "ref.h" #include namespace cxml { class Node; } namespace xmlpp { class Node; } namespace dcp { class Content; /** @class ReelAsset * @brief An entry in a <Reel> which refers to a use of a piece of content. * * This class encapsulates the XML that exists in a <Reel> to say * that a piece of content is used in this reel. It does not * describe the content itself (but links to a Content object which does). */ class ReelAsset : public Object { public: ReelAsset (); ReelAsset (boost::shared_ptr content, int64_t entry_point); ReelAsset (boost::shared_ptr); virtual void write_to_cpl (xmlpp::Node* node, Standard standard) const; virtual bool equals ( boost::shared_ptr, EqualityOptions, boost::function) const { return false; } /** @return a Ref to our actual content */ Ref& content () { return _content; } /** @return true if a KeyId is specified for this asset, implying * that its content is encrypted. */ bool encrypted () const { return !_key_id.empty (); } /** @return Key ID to describe the key that encrypts this asset's; * content. */ std::string key_id () const { return _key_id; } protected: /** @return the node name that this asset uses in the CPL's <Reel> node * e.g. MainPicture, MainSound etc. */ virtual std::string cpl_node_name () const = 0; /** @return Any attribute that should be used on the asset's node in the * CPL. */ virtual std::pair cpl_node_attribute () const; /** Reference to the content (MXF or XML file) that this reel entry * applies to. */ Ref _content; private: std::string _annotation_text; ///< The from the reel's entry for this asset Fraction _edit_rate; ///< The from the reel's entry for this asset int64_t _intrinsic_duration; ///< The from the reel's entry for this asset int64_t _entry_point; ///< The from the reel's entry for this asset int64_t _duration; ///< The from the reel's entry for this asset std::string _hash; ///< The from the reel's entry for this asset std::string _key_id; ///< The from the reel's entry for this asset, or empty if there isn't one }; } #endif