X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Freel_asset.h;h=a90436a80947e06c0d8acefd5af6258a972352e9;hb=d1f0b2b71a702b5624485cfeacaee5d58c4af5b2;hp=5207166a9e511eb41dd43d4c865de6e5d7ce2391;hpb=59886567974bd3e79d30a4a9425d86d50bf425f3;p=libdcp.git diff --git a/src/reel_asset.h b/src/reel_asset.h index 5207166a..a90436a8 100644 --- a/src/reel_asset.h +++ b/src/reel_asset.h @@ -1,22 +1,26 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2015 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of libdcp. + + libdcp 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, + libdcp 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. - + along with libdcp. If not, see . */ +/** @file src/reel_asset.h + * @brief ReelAsset class. + */ + #ifndef LIBDCP_REEL_ASSET_H #define LIBDCP_REEL_ASSET_H @@ -35,46 +39,85 @@ namespace xmlpp { namespace dcp { -class Content; +class Asset; +/** @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 an Asset object which does). + */ class ReelAsset : public Object { public: ReelAsset (); - ReelAsset (boost::shared_ptr content, int64_t entry_point); + ReelAsset (boost::shared_ptr asset, Fraction edit_rate, int64_t intrinsic_duration, int64_t entry_point); ReelAsset (boost::shared_ptr); - Ref content () const { - return _content; + virtual void write_to_cpl (xmlpp::Node* node, Standard standard) const; + virtual bool equals (boost::shared_ptr, EqualityOptions, NoteHandler) const; + + /** @return a Ref to our actual asset */ + Ref const & asset_ref () const { + return _asset_ref; } - bool encrypted () const { - return !_key_id.empty (); + /** @return a Ref to our actual asset */ + Ref & asset_ref () { + return _asset_ref; } - std::string key_id () const { - return _key_id; + Fraction edit_rate () const { + return _edit_rate; } - virtual void write_to_cpl (xmlpp::Node* node, Standard standard) const; - virtual bool equals (boost::shared_ptr, EqualityOptions, boost::function) const { - return false; + int64_t intrinsic_duration () const { + return _intrinsic_duration; + } + + int64_t entry_point () const { + return _entry_point; + } + + int64_t duration () const { + return _duration; } protected: + + template + boost::shared_ptr asset_of_type () const { + return boost::dynamic_pointer_cast (_asset_ref.asset ()); + } + + template + boost::shared_ptr asset_of_type () { + return boost::dynamic_pointer_cast (_asset_ref.asset ()); + } + + /** @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; - virtual std::pair cpl_node_attribute () const; - Ref _content; + /** @return Any attribute that should be used on the asset's node in the + * CPL. + */ + virtual std::pair cpl_node_attribute (Standard) const; + + /** Reference to the asset (MXF or XML file) that this reel entry + * applies to. + */ + Ref _asset_ref; private: - std::string _annotation_text; - Fraction _edit_rate; - int64_t _intrinsic_duration; - int64_t _entry_point; - int64_t _duration; - std::string _hash; - std::string _key_id; + std::string _annotation_text; ///< The <AnnotationText> from the reel's entry for this asset + Fraction _edit_rate; ///< The <EditRate> from the reel's entry for this asset + int64_t _intrinsic_duration; ///< The <IntrinsicDuration> from the reel's entry for this asset + int64_t _entry_point; ///< The <EntryPoint> from the reel's entry for this asset + int64_t _duration; ///< The <Duration> from the reel's entry for this asset + std::string _hash; ///< The <Hash> from the reel's entry for this asset }; }