X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fasset_reader.h;h=eaf2721a31dd355861d74d5d88960b52b5ec9e2b;hb=refs%2Fheads%2F1.0-templates;hp=09169a8e0b173ec3ab01c60f8bfc2b0b10150fe2;hpb=9486066c29b91a8d9ac25be1c596cad62387208f;p=libdcp.git diff --git a/src/asset_reader.h b/src/asset_reader.h index 09169a8e..eaf2721a 100644 --- a/src/asset_reader.h +++ b/src/asset_reader.h @@ -34,21 +34,45 @@ #ifndef LIBDCP_ASSET_READER_H #define LIBDCP_ASSET_READER_H +#include "dcp_assert.h" +#include "asset.h" +#include "decryption_context.h" +#include #include #include namespace dcp { -class MXF; class DecryptionContext; +template class AssetReader : public boost::noncopyable { public: - explicit AssetReader (MXF const * mxf); - virtual ~AssetReader () {} + explicit AssetReader (Asset const * asset, boost::optional key) + : _decryption_context (new DecryptionContext (key)) + { + _reader = new R (); + DCP_ASSERT (asset->file ()); + Kumu::Result_t const r = _reader->OpenRead (asset->file()->string().c_str()); + if (ASDCP_FAILURE (r)) { + delete _reader; + boost::throw_exception (FileError ("could not open MXF file for reading", asset->file().get(), r)); + } + } + + ~AssetReader () + { + delete _reader; + } + + boost::shared_ptr get_frame (int n) const + { + return boost::shared_ptr (new F (_reader, n, _decryption_context)); + } protected: + R* _reader; boost::shared_ptr _decryption_context; };