X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fcinema.cc;h=1902f15f9f4f091433f3fc10e12c8f4b5a301381;hp=62023618676a6f83de20bfde5f6be6acd651e1b7;hb=f515b8daea9d28200be803bb64ff17e9f30343c4;hpb=7b2054e2a73844450b5b55c5788c02af671812ce diff --git a/src/lib/cinema.cc b/src/lib/cinema.cc index 620236186..1902f15f9 100644 --- a/src/lib/cinema.cc +++ b/src/lib/cinema.cc @@ -1,34 +1,53 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ -#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; +using dcp::raw_convert; +using dcpomatic::Screen; Cinema::Cinema (cxml::ConstNodePtr node) : name (node->string_child ("Name")) - , email (node->string_child ("Email")) + , notes (node->optional_string_child("Notes").get_value_or("")) { + 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 +66,18 @@ 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("Notes")->add_child_text (notes); + + parent->add_child("UTCOffsetHour")->add_child_text (raw_convert (_utc_offset_hour)); + parent->add_child("UTCOffsetMinute")->add_child_text (raw_convert (_utc_offset_minute)); + + BOOST_FOREACH (shared_ptr i, _screens) { + i->as_xml (parent->add_child ("Screen")); } } @@ -67,21 +94,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; } - -