X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ffont.cc;h=c817d361018ce9c9bfc51068a4846e4ce06c284e;hb=refs%2Fheads%2Ffaster-subtitle-moving;hp=5cf30a2aae370704d985fc6fe31c102f0fcfaad3;hpb=a112eeb4d052b1212f94e95efd83a215213da691;p=dcpomatic.git diff --git a/src/lib/font.cc b/src/lib/font.cc index 5cf30a2aa..c817d3610 100644 --- a/src/lib/font.cc +++ b/src/lib/font.cc @@ -1,43 +1,90 @@ /* - 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 "dcpomatic_socket.h" +#include +#include #include +#include + +using std::string; +using boost::shared_ptr; +using dcp::raw_convert; +using namespace dcpomatic; Font::Font (cxml::NodePtr node) - : id (node->string_child ("Id")) - , file (node->optional_string_child ("File")) + : _id (node->string_child ("Id")) +{ + BOOST_FOREACH (cxml::NodePtr i, node->node_children("File")) { + string variant = i->optional_string_attribute("Variant").get_value_or ("Normal"); + if (variant == "Normal") { + _file = i->content(); + } + } +} + +void +Font::as_xml (xmlpp::Node* node) const { - + node->add_child("Id")->add_child_text (_id); + if (_file) { + node->add_child("File")->add_child_text(_file->string()); + } } +/** Add things to an XML node to describe this font for transfer across + * a network to another machine. The companion method send_binary() will be called + * to send binary parts. + */ void -Font::as_xml (xmlpp::Node* node) +Font::transfer_xml (xmlpp::Node* node) const { - 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 (_file) { + node->add_child("FileLength")->add_child_text(raw_convert(boost::filesystem::file_size(*_file))); } } +void +Font::transfer_binary (shared_ptr socket) const +{ + if (_file) { + dcp::Data data (*_file); + socket->write (data.data().get(), data.size()); + } +} + +bool +dcpomatic::operator== (Font const & a, Font const & b) +{ + if (a.id() != b.id()) { + return false; + } + + return a.file() == b.file(); +} + 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); + return !(a == b); }