X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Freel_sound_asset.cc;h=25259f427c6c596d6e974857826a05e2b9871907;hb=4c1a8e66f754d26e3db9c4c651e19ff4b6a94bb9;hp=6c9b0ceaf1ca89ab01025b032a906d2eda396da8;hpb=a641fdc912a3f0749015decdf9e23ff15186ef78;p=libdcp.git
diff --git a/src/reel_sound_asset.cc b/src/reel_sound_asset.cc
index 6c9b0cea..25259f42 100644
--- a/src/reel_sound_asset.cc
+++ b/src/reel_sound_asset.cc
@@ -15,6 +15,20 @@
You should have received a copy of the GNU General Public License
along with libdcp. If not, see .
+
+ In addition, as a special exception, the copyright holders give
+ permission to link the code of portions of this program with the
+ OpenSSL library under certain conditions as described in each
+ individual source file, and distribute linked combinations
+ including the two.
+
+ You must obey the GNU General Public License in all respects
+ for all of the code used other than OpenSSL. If you modify
+ file(s) with this exception, you may extend this exception to your
+ version of the file(s), but you are not obligated to do so. If you
+ do not wish to do so, delete this exception statement from your
+ version. If you delete this exception statement from all source
+ files in the program, then also delete it here.
*/
/** @file src/reel_sound_asset.cc
@@ -31,8 +45,8 @@ using boost::shared_ptr;
using namespace dcp;
ReelSoundAsset::ReelSoundAsset (shared_ptr asset, int64_t entry_point)
- : ReelAsset (asset, asset->edit_rate(), asset->intrinsic_duration(), entry_point)
- , ReelMXF (asset->key_id())
+ : ReelAsset (asset->id(), asset->edit_rate(), asset->intrinsic_duration(), entry_point)
+ , ReelMXF (asset, asset->key_id())
{
}
@@ -46,7 +60,7 @@ ReelSoundAsset::ReelSoundAsset (shared_ptr node)
}
string
-ReelSoundAsset::cpl_node_name () const
+ReelSoundAsset::cpl_node_name (Standard) const
{
return "MainSound";
}
@@ -57,16 +71,29 @@ ReelSoundAsset::key_type () const
return "MDAK";
}
-void
+xmlpp::Node *
ReelSoundAsset::write_to_cpl (xmlpp::Node* node, Standard standard) const
{
- ReelAsset::write_to_cpl (node, standard);
+ xmlpp::Node* asset = write_to_cpl_base (node, standard, hash());
if (key_id ()) {
- /* Find */
- xmlpp::Node* ms = find_child (node, cpl_node_name ());
/* Find */
- xmlpp::Node* hash = find_child (ms, "Hash");
- ms->add_child_before (hash, "KeyId")->add_child_text ("urn:uuid:" + key_id().get ());
+ xmlpp::Node* hash = find_child (asset, "Hash");
+ asset->add_child_before(hash, "KeyId")->add_child_text("urn:uuid:" + key_id().get());
}
+
+ return asset;
+}
+
+bool
+ReelSoundAsset::equals (shared_ptr other, EqualityOptions opt, NoteHandler note) const
+{
+ if (!asset_equals (other, opt, note)) {
+ return false;
+ }
+ if (!mxf_equals (other, opt, note)) {
+ return false;
+ }
+
+ return true;
}