diff options
Diffstat (limited to 'Src/Xml.h')
-rw-r--r-- | Src/Xml.h | 179 |
1 files changed, 179 insertions, 0 deletions
diff --git a/Src/Xml.h b/Src/Xml.h new file mode 100644 index 0000000..477a086 --- /dev/null +++ b/Src/Xml.h @@ -0,0 +1,179 @@ +/* + * Video On Demand Samples + * + * Copyright (C) 2015 Microchip Technology Germany II GmbH & Co. KG + * + * This program 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 3 of the License, or + * (at your option) any later version. + * + * This program 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, see <http://www.gnu.org/licenses/>. + * + * You may also obtain this software under a propriety license from Microchip. + * Please contact Microchip for further information. + * + */ + +/*----------------------------------------------------------*/ +/*! \file + * \brief This file contains the CXml class. + */ +/*----------------------------------------------------------*/ +#ifndef _XML_H_ +#define _XML_H_ + +#include "Types.h" +#include <libxml/tree.h> +#include <libxml/parser.h> + + +#define XML_DEFAULT_VALUE_LEN 255 + +/*----------------------------------------------------------*/ +/*! \brief Generic class to read XML files. It does not implement a concrete use case. + */ +/*----------------------------------------------------------*/ +class CXml +{ + xmlDoc *m_Doc; + xmlNode *m_Node; + bool m_bDocOpened; +protected: + static int ConvertToInt( xmlChar *xString ); + +public: + /*----------------------------------------------------------*/ + /*! \brief construct a XML document from a file name + */ + /*----------------------------------------------------------*/ + CXml( const char *szFile ); + + + /*----------------------------------------------------------*/ + /*! \brief construct a XML document from a zero terminated string in the memory. + */ + /*----------------------------------------------------------*/ + CXml( const char *szBuffer, uint32_t nBufferLen ); + + + /*----------------------------------------------------------*/ + /*! \brief construct a XML document from a given node + */ + /*----------------------------------------------------------*/ + CXml( CXml &Node ); + + + + /*----------------------------------------------------------*/ + /*! \brief construct a XML document from a file name + */ + /*----------------------------------------------------------*/ + ~CXml(); + + + + /*----------------------------------------------------------*/ + /*! \brief gets top node inside root of XML document + * + * \return true, if successful + */ + /*----------------------------------------------------------*/ + bool SetToTopNode(); + + + + /*----------------------------------------------------------*/ + /*! \brief find first child node + * + * \return true, if child node was found + */ + /*----------------------------------------------------------*/ + bool FindFirstChildNode(); + + + + + /*----------------------------------------------------------*/ + /*! \brief find next node on same level + * + * \return true, if node was found + */ + /*----------------------------------------------------------*/ + bool FindNextNode(); + + + + + /*----------------------------------------------------------*/ + /*! \brief find a XML node with a given tag + * + * \param szTag - tag looking for + * + * \return XML node + */ + /*----------------------------------------------------------*/ + bool FindNode( const xmlChar *szTag ); + + + + + + /*----------------------------------------------------------*/ + /*! \brief searches a node, which has a child node with a + * given value + * + * \param szNodeTag - tag of nodes which are included in search + * \param szValueTag - tag of value inside node + * \param szValue - value looked for + * + * \return XML true if found + */ + /*----------------------------------------------------------*/ + bool FindNodeWithValue( const xmlChar *szNodeTag, const xmlChar *szValueTag, const xmlChar *szValue ); + + + + /*----------------------------------------------------------*/ + /*! \brief searches node, which has a child node with a + * given integer value + * + * \param szNodeTag - tag of nodes which are included in search + * \param szValueTag - tag of value inside node + * \param szValue - value looked for + * + * \return true if found + */ + /*----------------------------------------------------------*/ + bool FindNodeWithValueInt( const xmlChar *szNodeTag, const xmlChar *szValueTag, int nValue ); + + /*----------------------------------------------------------*/ + /*! \brief get node's child value as string + * + * \param szTag - tag of the value inside the node + * + * \return value as string if found, otherwise NULL + */ + /*----------------------------------------------------------*/ + bool GetChildValue( const xmlChar *szTag, xmlChar *szValue, int nMaxLen = XML_DEFAULT_VALUE_LEN ); + + + /*----------------------------------------------------------*/ + /*! \brief get node's child value as int + * + * \param szTag - tag of the value inside the node + * \param nErr - value returned in case of an error + * + * \return value as int + */ + /*----------------------------------------------------------*/ + bool GetChildValueInt( const xmlChar *szTag, int &nValue ); +}; + +#endif |