X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Freel_subtitle_asset.cc;h=7636782f94b9b6fbf8d5a29dacb67cc9f5d067cb;hb=093525165f6397ba9eaffd19833dc978bcb32d55;hp=a90513d5c1fed7aede33b306526a85bb181aa735;hpb=9eba1ff84fd89e2ff04181799f2185c8575de16d;p=libdcp.git diff --git a/src/reel_subtitle_asset.cc b/src/reel_subtitle_asset.cc index a90513d5..7636782f 100644 --- a/src/reel_subtitle_asset.cc +++ b/src/reel_subtitle_asset.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2017 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington This file is part of libdcp. @@ -31,62 +31,69 @@ files in the program, then also delete it here. */ + /** @file src/reel_subtitle_asset.cc - * @brief ReelSubtitleAsset class. + * @brief ReelSubtitleAsset class */ + +#include "language_tag.h" #include "subtitle_asset.h" #include "reel_subtitle_asset.h" #include "smpte_subtitle_asset.h" #include + using std::string; -using boost::shared_ptr; -using boost::dynamic_pointer_cast; +using std::shared_ptr; +using std::dynamic_pointer_cast; using boost::optional; using namespace dcp; -ReelSubtitleAsset::ReelSubtitleAsset (boost::shared_ptr asset, Fraction edit_rate, int64_t intrinsic_duration, int64_t entry_point) + +ReelSubtitleAsset::ReelSubtitleAsset (std::shared_ptr asset, Fraction edit_rate, int64_t intrinsic_duration, int64_t entry_point) : ReelAsset (asset->id(), edit_rate, intrinsic_duration, entry_point) - , ReelMXF (asset, dynamic_pointer_cast(asset) ? dynamic_pointer_cast(asset)->key_id() : optional()) + , ReelEncryptableAsset (asset, dynamic_pointer_cast(asset) ? dynamic_pointer_cast(asset)->key_id() : optional()) { } -ReelSubtitleAsset::ReelSubtitleAsset (boost::shared_ptr node) + +ReelSubtitleAsset::ReelSubtitleAsset (std::shared_ptr node) : ReelAsset (node) - , ReelMXF (node) + , ReelEncryptableAsset (node) { - node->ignore_child ("Language"); + _language = node->optional_string_child("Language"); node->done (); } + string ReelSubtitleAsset::cpl_node_name (Standard) const { return "MainSubtitle"; } + string ReelSubtitleAsset::key_type () const { return "MDSK"; } + xmlpp::Node * ReelSubtitleAsset::write_to_cpl (xmlpp::Node* node, Standard standard) const { - xmlpp::Node* asset = write_to_cpl_base (node, standard, hash()); - - if (key_id ()) { - /* Find */ - xmlpp::Node* hash = find_child (asset, "Hash"); - asset->add_child_before(hash, "KeyId")->add_child_text("urn:uuid:" + key_id().get()); + auto asset = write_to_cpl_asset (node, standard, hash()); + write_to_cpl_mxf (asset); + if (_language) { + asset->add_child("Language")->add_child_text(*_language); } - return asset; } + bool ReelSubtitleAsset::equals (shared_ptr other, EqualityOptions opt, NoteHandler note) const { @@ -99,3 +106,11 @@ ReelSubtitleAsset::equals (shared_ptr other, EqualityOp return true; } + + +void +ReelSubtitleAsset::set_language (dcp::LanguageTag language) +{ + _language = language.to_string(); +} +