X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Fxmlutil.cpp;h=600ba5c6a29c5cee4e122deba83df3b190267bee;hb=245ef75a37af52afa0fea2c52b1f2454f72f7394;hp=eca6f16d4ebcf9ca221a6a9d662f3be452cc298f;hpb=891f355967146e1f2d66e4dc44158a011282c87f;p=metaproxy-moved-to-github.git diff --git a/src/xmlutil.cpp b/src/xmlutil.cpp index eca6f16..600ba5c 100644 --- a/src/xmlutil.cpp +++ b/src/xmlutil.cpp @@ -1,4 +1,4 @@ -/* $Id: xmlutil.cpp,v 1.2 2006-01-11 11:51:50 adam Exp $ +/* $Id: xmlutil.cpp,v 1.3 2006-01-11 13:13:49 adam Exp $ Copyright (c) 2005, Index Data. %LICENSE% @@ -33,6 +33,15 @@ bool yp2::xml::is_element_yp2(const xmlNode *ptr, return yp2::xml::is_element(ptr, "http://indexdata.dk/yp2/config/1", name); } + +bool yp2::xml::check_element_yp2(const xmlNode *ptr, + const std::string &name) +{ + if (!yp2::xml::is_element_yp2(ptr, name)) + throw yp2::XMLError("Expected element name " + name); + return true; +} + std::string yp2::xml::get_route(const xmlNode *node) { std::string route_value; @@ -58,6 +67,34 @@ std::string yp2::xml::get_route(const xmlNode *node) return route_value; } + +const xmlNode* yp2::xml::jump_to_children(const xmlNode* node, + int xml_node_type) +{ + node = node->children; + for (; node && node->type != xml_node_type; node = node->next) + ; + return node; +} + +const xmlNode* yp2::xml::jump_to_next(const xmlNode* node, + int xml_node_type) +{ + node = node->next; + for (; node && node->type != xml_node_type; node = node->next) + ; + return node; +} + +const xmlNode* yp2::xml::jump_to(const xmlNode* node, + int xml_node_type) +{ + for (; node && node->type != xml_node_type; node = node->next) + ; + return node; +} + + /* * Local variables: * c-basic-offset: 4