X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Ffont.cc;h=333539aa4b7cbc6441dbc2e5c75dae4d0f7752a3;hp=0e1ad85cdf2bb6a248b6e75d770c442cfbcc2a2b;hb=HEAD;hpb=2a01820de9229fd778787421ec4f7bbf1e4b8bf1 diff --git a/src/lib/font.cc b/src/lib/font.cc index 0e1ad85cd..955a2ad1c 100644 --- a/src/lib/font.cc +++ b/src/lib/font.cc @@ -1,43 +1,111 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-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 "dcpomatic_assert.h" #include "font.h" +#include +LIBDCP_DISABLE_WARNINGS #include +LIBDCP_ENABLE_WARNINGS + + +using std::string; +using boost::optional; +using namespace dcpomatic; + Font::Font (cxml::NodePtr node) - : _id (node->string_child ("Id")) - , _file (node->optional_string_child ("File")) + : _id (node->string_child("Id")) +{ + for (auto i: node->node_children("File")) { + string variant = i->optional_string_attribute("Variant").get_value_or("Normal"); + if (variant == "Normal") { + _content.file = i->content(); + } + } +} + + +Font::Font(Font const& other) + : _id(other._id) + , _content(other._content) { - + } + +Font& Font::operator=(Font const& other) +{ + if (&other != this) { + _id = other._id; + _content = other._content; + } + return *this; +} + + void Font::as_xml (xmlpp::Node* node) { - node->add_child("Id")->add_child_text (_id); - if (_file) { - node->add_child("File")->add_child_text (_file.get().string ()); + node->add_child("Id")->add_child_text(_id); + if (_content.file) { + node->add_child("File")->add_child_text(_content.file->string()); } } + bool -operator!= (Font const & a, Font const & b) +dcpomatic::operator== (Font const & a, Font const & b) { - return (a.id() != b.id() || a.file() != b.file()); + if (a.id() != b.id()) { + return false; + } + + /* XXX: it's dubious that this ignores _data, though I think it's OK for the cases + * where operator== is used. Perhaps we should remove operator== and have a more + * specific comparator. + */ + + return a.file() == b.file(); } + + +bool +dcpomatic::operator!= (Font const & a, Font const & b) +{ + return !(a == b); +} + + +optional +Font::data () const +{ + if (_content.data) { + return _content.data; + } + + if (_content.file) { + return dcp::ArrayData(*_content.file); + } + + return {}; +} +