/* * This source file is part of RmlUi, the HTML/CSS Interface Middleware * * For the latest information, see http://github.com/mikke89/RmlUi * * Copyright (c) 2008-2010 CodePoint Ltd, Shift Technology Ltd * Copyright (c) 2019 The RmlUi Team, and contributors * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. * */ #include "XmlNodeHandlers.h" #include #include #include #include using namespace Rml; class XMLNodeHandlerMeta : public Rml::XMLNodeHandler { public: XMLNodeHandlerMeta(MetaList* meta_list) : meta_list(meta_list) {} ~XMLNodeHandlerMeta() {} /// Called when a new element start is opened Element* ElementStart(XMLParser* /*parser*/, const String& /*name*/, const XMLAttributes& attributes) override { MetaItem item; auto it_name = attributes.find("name"); if (it_name != attributes.end()) item.name = it_name->second.Get(); auto it_content = attributes.find("content"); if (it_content != attributes.end()) item.content = it_content->second.Get(); if (!item.name.empty() && !item.content.empty()) meta_list->push_back(std::move(item)); return nullptr; } /// Called when an element is closed bool ElementEnd(XMLParser* /*parser*/, const String& /*name*/) override { return true; } /// Called for element data bool ElementData(XMLParser* /*parser*/, const String& /*data*/, XMLDataType /*type*/) override { return true; } private: MetaList* meta_list; }; class XMLNodeHandlerLink : public Rml::XMLNodeHandler { public: XMLNodeHandlerLink(LinkList* link_list) : link_list(link_list) { node_handler_head = XMLParser::GetNodeHandler("head"); RMLUI_ASSERT(node_handler_head); } ~XMLNodeHandlerLink() {} Element* ElementStart(XMLParser* parser, const String& name, const XMLAttributes& attributes) override { RMLUI_ASSERT(name == "link"); const String rel = StringUtilities::ToLower(Get(attributes, "rel", "")); const String type = StringUtilities::ToLower(Get(attributes, "type", "")); const String href = Get(attributes, "href", ""); if (!type.empty() && !href.empty()) { // Pass it on to the head handler if it's a type it handles. if (type == "text/rcss" || type == "text/css" || type == "text/template") { return node_handler_head->ElementStart(parser, name, attributes); } } LinkItem item{ rel, href }; if (rel == "match") item.href = StringUtilities::Replace(href, '/', '\\'); else item.href = href; link_list->push_back(std::move(item)); return nullptr; } bool ElementEnd(XMLParser* parser, const String& name) override { return node_handler_head->ElementEnd(parser, name); } bool ElementData(XMLParser* parser, const String& data, XMLDataType type) override { return node_handler_head->ElementData(parser, data, type); } private: LinkList* link_list; Rml::XMLNodeHandler* node_handler_head; }; static SharedPtr meta_handler; static SharedPtr link_handler; void InitializeXmlNodeHandlers(MetaList* meta_list, LinkList* link_list) { meta_handler = MakeShared(meta_list); REQUIRE(meta_handler); Rml::XMLParser::RegisterNodeHandler("meta", meta_handler); link_handler = MakeShared(link_list); REQUIRE(link_handler); Rml::XMLParser::RegisterNodeHandler("link", link_handler); }