X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fcinema.cc;h=7e13b50aea775ef4900b637e145913aa742c92a8;hb=ff639b3cf30afcc097bfd21d39c8d15f466cadd6;hp=5e2b1b533bb49df0926844c15366fec3ff88e063;hpb=581ea73e56388d87a0c7f736efce447076618393;p=dcpomatic.git diff --git a/src/lib/cinema.cc b/src/lib/cinema.cc index 5e2b1b533..7e13b50ae 100644 --- a/src/lib/cinema.cc +++ b/src/lib/cinema.cc @@ -1,42 +1,56 @@ /* - Copyright (C) 2013-2016 Carl Hetherington + Copyright (C) 2013-2021 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 "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 std::shared_ptr; +using std::make_shared; +using dcp::raw_convert; +using dcpomatic::Screen; + Cinema::Cinema (cxml::ConstNodePtr node) : name (node->string_child ("Name")) - , _utc_offset (node->optional_number_child("UTCOffset").get_value_or (0)) + , notes (node->optional_string_child("Notes").get_value_or("")) { - BOOST_FOREACH (cxml::ConstNodePtr i, node->node_children("Email")) { + for (auto 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 @@ -45,9 +59,8 @@ Cinema::Cinema (cxml::ConstNodePtr node) void Cinema::read_screens (cxml::ConstNodePtr node) { - list s = node->node_children ("Screen"); - for (list::iterator i = s.begin(); i != s.end(); ++i) { - add_screen (shared_ptr (new Screen (*i))); + for (auto i: node->node_children("Screen")) { + add_screen (make_shared(i)); } } @@ -56,13 +69,16 @@ Cinema::as_xml (xmlpp::Element* parent) const { parent->add_child("Name")->add_child_text (name); - BOOST_FOREACH (string i, emails) { + for (auto i: emails) { parent->add_child("Email")->add_child_text (i); } - parent->add_child("UTCOffset")->add_child_text (dcp::raw_convert (_utc_offset)); + 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) { + for (auto i: _screens) { i->as_xml (parent->add_child ("Screen")); } } @@ -81,8 +97,15 @@ Cinema::remove_screen (shared_ptr s) } void -Cinema::set_utc_offset (int o) +Cinema::set_utc_offset_hour (int h) +{ + DCPOMATIC_ASSERT (h >= -11 && h <= 12); + _utc_offset_hour = h; +} + +void +Cinema::set_utc_offset_minute (int m) { - DCPOMATIC_ASSERT (o >= -11 && o <= 12); - _utc_offset = o; + DCPOMATIC_ASSERT (m >= 0 && m <= 59); + _utc_offset_minute = m; }