/* Copyright (C) 2012 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. */ /** @file src/dcp.h * @brief A class to create a DCP. */ #ifndef LIBDCP_DCP_H #define LIBDCP_DCP_H #include #include #include #include #include "types.h" namespace xmlpp { class Node; } /** @brief Namespace for everything in libdcp */ namespace libdcp { class Asset; class PictureAsset; class SoundAsset; class SubtitleAsset; class Reel; class CPL; class XMLMetadata; /** @class DCP * @brief A class to create or read a DCP. */ class DCP { public: /** Construct a DCP. You can pass an existing DCP's directory * as the parameter, or a non-existant folder to create a new * DCP in. * * @param directory Directory containing the DCP's files. */ DCP (std::string directory); /** Read an existing DCP's data. * * The DCP's XML metadata will be examined, and you can then look at the contents * of the DCP. * * @param require_mxfs true to throw an exception if MXF files are missing; setting to false * can be useful for testing, but normally it should be set to true. */ void read (bool require_mxfs = true); /** Write the required XML files to the directory that was * passed into the constructor. */ void write_xml (XMLMetadata const &) const; /** Compare this DCP with another, according to various options. * @param other DCP to compare this one to. * @param options Options to define what "equality" means. * @return true if the DCPs are equal according to EqualityOptions, otherwise false. */ bool equals (DCP const & other, EqualityOptions options, boost::function note) const; /** Add a CPL to this DCP. * @param cpl CPL to add. */ void add_cpl (boost::shared_ptr cpl); /** @return The list of CPLs in this DCP */ std::list > cpls () const { return _cpls; } /** Emitted with a parameter between 0 and 1 to indicate progress * for long jobs. */ boost::signals2::signal Progress; private: /** Write the PKL file. * @param pkl_uuid UUID to use. */ std::string write_pkl (std::string pkl_uuid, XMLMetadata const &) const; /** Write the VOLINDEX file */ void write_volindex () const; /** Write the ASSETMAP file. * @param pkl_uuid UUID of our PKL. * @param pkl_length Length of our PKL in bytes. */ void write_assetmap (std::string pkl_uuid, int pkl_length, XMLMetadata const &) const; /** @return Assets in all this CPLs in this DCP */ std::list > assets () const; struct Files { std::list cpls; std::string pkl; std::string asset_map; }; /** the directory that we are writing to */ std::string _directory; /** our CPLs */ std::list > _cpls; }; } #endif