forgetIt/ParserClass/FileManParser.hpp
2015-03-14 20:11:18 +04:00

114 lines
2.5 KiB
C++

/**
* @file FileManParser.hpp
* @brief FileManParser class definitions
* @author manzerbredes
* @date 11 Mars 2015
*
* Contain all definitions of FileManParser class.
*
*/
#ifndef __FileManParser__
#define __FileManParser__
//----- std -----
#include <iostream>
#include <sstream>
#include <string>
#include <vector>
//----- class -----
#include "Website.hpp"
//----- libxml++ -----
#include <cstdlib>
#include <libxml++/libxml++.h>
/**
* @class FileManParser FileManParser.hpp "/ParserClass/FileManContainer/FileManParser.hpp"
* @brief Class for parser un xml file in a string.
* @author manzerbredes
*
* Parse string using libxml++ library.
*
*/
class FileManParser{
public:
//Constructor
FileManParser(std::string data);
/**
* @brief Get document in string
*
* @return a string that contain the document
*
* Return current document.
* To have an up-to-date document, please run updateParser() before.
*
*/
std::string getDocument();
/**
* @brief Write data in encrypted file.
*
* @return vector pointer that point to the vector of website in document
*
* You can modified this vector, and for apply change run updateParser()
*
*/
std::vector<Website>* getWebsites();
/**
* @brief Update the parser
*
* Apply all modifications you have made on the vector object (example std::vector<Website>* websites).
*
*/
void updateParser();
private:
/**
* @brief Instanciate websites vector
*
* Read the document and create all Website object and put them into
* the websites vector attribute.
*
*/
void initWebsites();
//Parser attributes
std::stringstream dataStream; ///< Contain the document you want to parse
xmlpp::DomParser parser; ///< Contain the parser
//Document attributes
xmlpp::Document* document; ///< Contain the document (generate by the parser and dataStream)
xmlpp::Node* rootNode; ///< Contain the root node of the document
//Website attributes
xmlpp::Node* websitesNode; ///< Contain the websites node of the document
std::vector<Website> *websites; ///< Contain all website of the document (you can modify it and run updateParser to apply all modifications).
};
#endif