X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fcinema.cc;h=e9a7dce6882e08f52722e7733ea05071d6b88443;hp=62023618676a6f83de20bfde5f6be6acd651e1b7;hb=c74d789ed75e87bccd094f45f082674f8f8d2f2f;hpb=7b2054e2a73844450b5b55c5788c02af671812ce diff --git a/src/lib/cinema.cc b/src/lib/cinema.cc index 620236186..e9a7dce68 100644 --- a/src/lib/cinema.cc +++ b/src/lib/cinema.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2016 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 @@ -17,18 +17,33 @@ */ -#include -#include #include "cinema.h" +#include "screen.h" +#include "dcpomatic_assert.h" +#include +#include +#include +#include +#include using std::list; +using std::string; using boost::shared_ptr; Cinema::Cinema (cxml::ConstNodePtr node) : name (node->string_child ("Name")) - , email (node->string_child ("Email")) { + BOOST_FOREACH (cxml::ConstNodePtr i, node->node_children("Email")) { + emails.push_back (i->content ()); + } + + if (node->optional_number_child("UTCOffset")) { + _utc_offset_hour = node->number_child("UTCOffset"); + } else { + _utc_offset_hour = node->optional_number_child("UTCOffsetHour").get_value_or (0); + } + _utc_offset_minute = node->optional_number_child("UTCOffsetMinute").get_value_or (0); } /* This is necessary so that we can use shared_from_this in add_screen (which cannot be done from @@ -47,10 +62,16 @@ void Cinema::as_xml (xmlpp::Element* parent) const { parent->add_child("Name")->add_child_text (name); - parent->add_child("Email")->add_child_text (email); - for (list >::const_iterator i = _screens.begin(); i != _screens.end(); ++i) { - (*i)->as_xml (parent->add_child ("Screen")); + BOOST_FOREACH (string i, emails) { + parent->add_child("Email")->add_child_text (i); + } + + parent->add_child("UTCOffsetHour")->add_child_text (dcp::raw_convert (_utc_offset_hour)); + parent->add_child("UTCOffsetMinute")->add_child_text (dcp::raw_convert (_utc_offset_minute)); + + BOOST_FOREACH (shared_ptr i, _screens) { + i->as_xml (parent->add_child ("Screen")); } } @@ -67,21 +88,16 @@ Cinema::remove_screen (shared_ptr s) _screens.remove (s); } -Screen::Screen (cxml::ConstNodePtr node) +void +Cinema::set_utc_offset_hour (int h) { - name = node->string_child ("Name"); - if (node->optional_string_child ("Certificate")) { - certificate = dcp::Certificate (node->string_child ("Certificate")); - } + DCPOMATIC_ASSERT (h >= -11 && h <= 12); + _utc_offset_hour = h; } void -Screen::as_xml (xmlpp::Element* parent) const +Cinema::set_utc_offset_minute (int m) { - parent->add_child("Name")->add_child_text (name); - if (certificate) { - parent->add_child("Certificate")->add_child_text (certificate->certificate (true)); - } + DCPOMATIC_ASSERT (m >= 0 && m <= 59); + _utc_offset_minute = m; } - -