X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Frouter_flexml.cpp;h=2af087fbe97a6023e175a1ef5be03c5e2422dd12;hb=63d38d164424c752c996268074b0313e27848703;hp=36d036588d7e2f945701d57235ce2d06fe05df8f;hpb=b70b9ec78f0ab1c3ed3b432de986159129a0e4ed;p=metaproxy-moved-to-github.git diff --git a/src/router_flexml.cpp b/src/router_flexml.cpp index 36d0365..2af087f 100644 --- a/src/router_flexml.cpp +++ b/src/router_flexml.cpp @@ -1,8 +1,20 @@ -/* $Id: router_flexml.cpp,v 1.20 2007-01-25 14:05:54 adam Exp $ - Copyright (c) 2005-2007, Index Data. +/* This file is part of Metaproxy. + Copyright (C) 2005-2008 Index Data - See the LICENSE file for details - */ +Metaproxy 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, or (at your option) any later +version. + +Metaproxy 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ #include "config.hpp" #include "xmlutil.hpp" @@ -13,6 +25,7 @@ #include #include #include +#include #include @@ -34,7 +47,7 @@ namespace metaproxy_1 { friend class RouterFleXML::Pos; Rep(); - void base(xmlDocPtr doc, mp::FactoryFilter &factory); + void base(xmlDocPtr doc, mp::FactoryFilter &factory, bool test_only); typedef std::map > @@ -48,10 +61,12 @@ namespace metaproxy_1 { std::string m_dl_path; - void parse_xml_config_dom(xmlDocPtr doc); + void parse_xml_config_dom(xmlDocPtr doc, bool test_only); - void parse_xml_filters(xmlDocPtr doc, const xmlNode *node); - void parse_xml_routes(xmlDocPtr doc, const xmlNode *node); + void parse_xml_filters(xmlDocPtr doc, const xmlNode *node, + bool test_only); + void parse_xml_routes(xmlDocPtr doc, const xmlNode *node, + bool test_only); bool m_xinclude; private: @@ -72,7 +87,8 @@ namespace metaproxy_1 { } void mp::RouterFleXML::Rep::parse_xml_filters(xmlDocPtr doc, - const xmlNode *node) + const xmlNode *node, + bool test_only) { unsigned int filter_nr = 0; while(node && mp::xml::check_element_mp(node, "filter")) @@ -101,13 +117,13 @@ void mp::RouterFleXML::Rep::parse_xml_filters(xmlDocPtr doc, if (!m_factory->exist(type_value)) { - std::cout << "about to load " << type_value << ", path=" << - m_dl_path << "\n"; + yaz_log(YLOG_LOG, "Loading %s (dlpath %s)", + type_value.c_str(), m_dl_path.c_str()); m_factory->add_creator_dl(type_value, m_dl_path); } mp::filter::Base* filter_base = m_factory->create(type_value); - filter_base->configure(node); + filter_base->configure(node, test_only); if (m_id_filter_map.find(id_value) != m_id_filter_map.end()) throw mp::XMLError("Filter " + id_value + " already defined"); @@ -120,7 +136,8 @@ void mp::RouterFleXML::Rep::parse_xml_filters(xmlDocPtr doc, } void mp::RouterFleXML::Rep::parse_xml_routes(xmlDocPtr doc, - const xmlNode *node) + const xmlNode *node, + bool test_only) { mp::xml::check_element_mp(node, "route"); @@ -192,13 +209,13 @@ void mp::RouterFleXML::Rep::parse_xml_routes(xmlDocPtr doc, { if (!m_factory->exist(type_value)) { - std::cout << "about to load " << type_value << ", path=" << - m_dl_path << "\n"; + yaz_log(YLOG_LOG, "Loading %s (dlpath %s)", + type_value.c_str(), m_dl_path.c_str()); m_factory->add_creator_dl(type_value, m_dl_path); } mp::filter::Base* filter_base = m_factory->create(type_value); - filter_base->configure(node3); + filter_base->configure(node3, test_only); route.m_list.push_back( boost::shared_ptr(filter_base)); @@ -217,7 +234,8 @@ void mp::RouterFleXML::Rep::parse_xml_routes(xmlDocPtr doc, } } -void mp::RouterFleXML::Rep::parse_xml_config_dom(xmlDocPtr doc) +void mp::RouterFleXML::Rep::parse_xml_config_dom(xmlDocPtr doc, + bool test_only) { if (!doc) throw mp::XMLError("Empty XML Document"); @@ -258,14 +276,16 @@ void mp::RouterFleXML::Rep::parse_xml_config_dom(xmlDocPtr doc) if (mp::xml::is_element_mp(node, "filters")) { parse_xml_filters(doc, mp::xml::jump_to_children(node, - XML_ELEMENT_NODE)); + XML_ELEMENT_NODE), + test_only); node = mp::xml::jump_to_next(node, XML_ELEMENT_NODE); } // process node which is expected third element node mp::xml::check_element_mp(node, "routes"); - parse_xml_routes(doc, mp::xml::jump_to_children(node, XML_ELEMENT_NODE)); + parse_xml_routes(doc, mp::xml::jump_to_children(node, XML_ELEMENT_NODE), + test_only); node = mp::xml::jump_to_next(node, XML_ELEMENT_NODE); if (node) @@ -279,20 +299,23 @@ mp::RouterFleXML::Rep::Rep() : m_xinclude(false) { } -void mp::RouterFleXML::Rep::base(xmlDocPtr doc, mp::FactoryFilter &factory) +void mp::RouterFleXML::Rep::base(xmlDocPtr doc, mp::FactoryFilter &factory, + bool test_only) { m_factory = &factory; - parse_xml_config_dom(doc); + parse_xml_config_dom(doc, test_only); m_start_route = "start"; } -mp::RouterFleXML::RouterFleXML(xmlDocPtr doc, mp::FactoryFilter &factory) +mp::RouterFleXML::RouterFleXML(xmlDocPtr doc, mp::FactoryFilter &factory, + bool test_only) : m_p(new Rep) { - m_p->base(doc, factory); + m_p->base(doc, factory, test_only); } -mp::RouterFleXML::RouterFleXML(std::string xmlconf, mp::FactoryFilter &factory) +mp::RouterFleXML::RouterFleXML(std::string xmlconf, mp::FactoryFilter &factory, + bool test_only) : m_p(new Rep) { LIBXML_TEST_VERSION; @@ -303,7 +326,7 @@ mp::RouterFleXML::RouterFleXML(std::string xmlconf, mp::FactoryFilter &factory) throw mp::XMLError("xmlParseMemory failed"); else { - m_p->base(doc, factory); + m_p->base(doc, factory, test_only); xmlFreeDoc(doc); } } @@ -316,7 +339,7 @@ const mp::filter::Base *mp::RouterFleXML::Pos::move(const char *route) { if (route && *route) { - std::cout << "move to " << route << "\n"; + //std::cout << "move to " << route << "\n"; m_route_it = m_p->m_routes.find(route); if (m_route_it == m_p->m_routes.end()) { @@ -364,8 +387,9 @@ mp::RouterFleXML::Pos::~Pos() /* * Local variables: * c-basic-offset: 4 + * c-file-style: "Stroustrup" * indent-tabs-mode: nil - * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */ +