X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ffont.cc;h=309f3d1eb3a6eab77673d75b5d58802b9c376a6e;hb=72b11d5eb036651b6ff68edf3ed270e8fc52960f;hp=bf7a79a3dfcd91aca9e167bf70463d8589d3cdc0;hpb=ed8491f8c5710ad8901021a12c3b187e29201f71;p=dcpomatic.git diff --git a/src/lib/font.cc b/src/lib/font.cc index bf7a79a3d..309f3d1eb 100644 --- a/src/lib/font.cc +++ b/src/lib/font.cc @@ -1,45 +1,85 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2015 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 "font.h" +#include "dcpomatic_assert.h" #include +#include + +using std::string; + +static char const * names[] = { + "Normal", + "Italic", + "Bold" +}; Font::Font (cxml::NodePtr node) + : _id (node->string_child ("Id")) { - id = node->optional_string_child ("Id"); - file = node->optional_string_child ("File"); + DCPOMATIC_ASSERT (FontFiles::VARIANTS == 3); + + BOOST_FOREACH (cxml::NodePtr i, node->node_children ("File")) { + string variant = i->optional_string_attribute("Variant").get_value_or ("Normal"); + for (int j = 0; j < FontFiles::VARIANTS; ++j) { + if (variant == names[j]) { + _files.set (static_cast(j), i->content()); + } + } + } } void Font::as_xml (xmlpp::Node* node) { - if (id) { - node->add_child("Id")->add_child_text (id.get ()); + DCPOMATIC_ASSERT (FontFiles::VARIANTS == 3); + + node->add_child("Id")->add_child_text (_id); + for (int i = 0; i < FontFiles::VARIANTS; ++i) { + if (_files.get(static_cast(i))) { + xmlpp::Element* e = node->add_child ("File"); + e->set_attribute ("Variant", names[i]); + e->add_child_text (_files.get(static_cast(i)).get().string ()); + } } +} - if (file) { - node->add_child("File")->add_child_text (file.get().string ()); + +bool +operator== (Font const & a, Font const & b) +{ + if (a.id() != b.id()) { + return false; } + + for (int i = 0; i < FontFiles::VARIANTS; ++i) { + if (a.file(static_cast(i)) != b.file(static_cast(i))) { + return false; + } + } + + return true; } bool operator!= (Font const & a, Font const & b) { - return (a.id != b.id || a.file != b.file); + return !(a == b); }