diff options
Diffstat (limited to 'ParserClass/FileManParser.cpp')
| -rw-r--r-- | ParserClass/FileManParser.cpp | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/ParserClass/FileManParser.cpp b/ParserClass/FileManParser.cpp index 43b3302..00db891 100644 --- a/ParserClass/FileManParser.cpp +++ b/ParserClass/FileManParser.cpp @@ -7,3 +7,95 @@ * Contain all implementations of FileManParser class. * */ + + +#include "FileManParser.hpp" + + +FileManParser::FileManParser(std::string data){ + this->data=data; + + try { + xercesc::XMLPlatformUtils::Initialize(); + } + catch (const xercesc::XMLException& toCatch) { + // Do your failure processing here + + } + + + xercesc::XercesDOMParser *parser = new xercesc::XercesDOMParser(); + xercesc::MemBufInputSource myxml_buf((const XMLByte*)this->data.c_str(), this->data.size(), "dummy",false); + + parser->parse("Doxygen/doc.xml"); + + + this->document=parser->getDocument(); + this->root=this->document->getDocumentElement(); + + this->initWebsites(); + + + +} + + + +std::vector<Website> FileManParser::getWebsites(){ + return this->websites; +} + + +std::string FileManParser::getData(){ return this->data;}; + + + +void FileManParser::initWebsites(){ + + xercesc::DOMElement* websitesElement=this->getChildByTagName(this->root, "websites"); + + + xercesc::DOMNodeList* nodeList=websitesElement->getChildNodes(); + XMLSize_t nodeCount = nodeList->getLength(); + + for(int i=0;i<nodeCount;i++){ + + xercesc::DOMNode* current=nodeList->item(i); + std::string TagName=xercesc::XMLString::transcode(current->getNodeName()); + + if( current->getNodeType() == xercesc::DOMNode::ELEMENT_NODE ) { + + std::cout << this->getContentOfChild(dynamic_cast< xercesc::DOMElement* >( current ),"title"); + std::cout << this->getContentOfChild(dynamic_cast< xercesc::DOMElement* >( current ),"url"); + + } + } +} + + +xercesc::DOMElement* FileManParser::getChildByTagName(xercesc::DOMElement* node, std::string TagName){ + xercesc::DOMNodeList* nodeList=node->getChildNodes(); + XMLSize_t nodeCount = nodeList->getLength(); + xercesc::DOMElement* returnElement=NULL; + + for(int i=0;i<nodeCount;i++){ + + xercesc::DOMNode* current=nodeList->item(i); + std::string currentTagName=xercesc::XMLString::transcode(current->getNodeName()); + + if( current->getNodeType() == xercesc::DOMNode::ELEMENT_NODE ) { + if(currentTagName.compare(TagName)==0){ + returnElement=dynamic_cast< xercesc::DOMElement* >( current ); + break; + } + } + } + + return returnElement; +} + + +std::string FileManParser::getContentOfChild(xercesc::DOMElement* node,std::string TagName){ + xercesc::DOMElement* child=this->getChildByTagName(node,TagName); + return xercesc::XMLString::transcode(child->getTextContent()); +} |
