diff options
| author | Carl Hetherington <cth@carlh.net> | 2020-04-21 23:32:42 +0200 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2020-04-21 23:51:38 +0200 |
| commit | 5f3a88d3ab1e9c1a13d7e61fc37a0c4cef8df9a5 (patch) | |
| tree | d9d66af89bd2c9864ad5242e5aaece551e72ce1e /src/lib/dcp_content.cc | |
| parent | f5980767b7d1d9b39186dd13f12b9d8297a87aef (diff) | |
Allow DCP content to store and serialise metadata.
Diffstat (limited to 'src/lib/dcp_content.cc')
| -rw-r--r-- | src/lib/dcp_content.cc | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/lib/dcp_content.cc b/src/lib/dcp_content.cc index 6c2db91d3..4280ad13a 100644 --- a/src/lib/dcp_content.cc +++ b/src/lib/dcp_content.cc @@ -151,6 +151,12 @@ DCPContent::DCPContent (cxml::ConstNodePtr node, int version) BOOST_FOREACH (cxml::ConstNodePtr i, node->node_children("Marker")) { _markers[dcp::marker_from_string(i->string_attribute("type"))] = ContentTime(raw_convert<int64_t>(i->content())); } + + BOOST_FOREACH (cxml::ConstNodePtr i, node->node_children("Rating")) { + _ratings.push_back (dcp::Rating(i)); + } + + _content_version = node->optional_string_child("ContentVersion").get_value_or(""); } void @@ -249,6 +255,8 @@ DCPContent::examine (shared_ptr<const Film> film, shared_ptr<Job> job) for (map<dcp::Marker, dcp::Time>::const_iterator i = markers.begin(); i != markers.end(); ++i) { _markers[i->first] = ContentTime(i->second.as_editable_units(DCPTime::HZ)); } + _ratings = examiner->ratings (); + _content_version = examiner->content_version (); } if (old_texts == texts) { @@ -354,6 +362,13 @@ DCPContent::as_xml (xmlpp::Node* node, bool with_paths) const marker->set_attribute("type", dcp::marker_to_string(i->first)); marker->add_child_text(raw_convert<string>(i->second.get())); } + + BOOST_FOREACH (dcp::Rating i, _ratings) { + xmlpp::Element* rating = node->add_child("Rating"); + i.as_xml (rating); + } + + node->add_child("ContentVersion")->add_child_text (_content_version); } DCPTime |
