//////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////
//
// copyright : (C) 2008 by Eran Ifrah
// file name : xmlutils.h
//
// -------------------------------------------------------------------------
// A
// _____ _ _ _ _
// / __ \ | | | | (_) |
// | / \/ ___ __| | ___| | _| |_ ___
// | | / _ \ / _ |/ _ \ | | | __/ _ )
// | \__/\ (_) | (_| | __/ |___| | || __/
// \____/\___/ \__,_|\___\_____/_|\__\___|
//
// F i l e
//
// 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 2 of the License, or
// (at your option) any later version.
//
//////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////
#ifndef XMLUTILS_H
#define XMLUTILS_H
#include "wx/xml/xml.h"
#ifdef WXMAKINGDLL_LE_SDK
# define WXDLLIMPEXP_LE_SDK WXEXPORT
#elif defined(WXUSINGDLL_LE_SDK)
# define WXDLLIMPEXP_LE_SDK WXIMPORT
#else /* not making nor using FNB as DLL */
# define WXDLLIMPEXP_LE_SDK
#endif // WXMAKINGDLL_LE_SDK
/// A collection of XML utils
class WXDLLIMPEXP_LE_SDK XmlUtils {
public:
/// Find a child node by name by iterating the parent children. NULL if no childs exist
/// \param parent the parent node whom to be searched
/// \param tagName the element tag name
/// \param name the element 'Name' property value to search
static wxXmlNode *FindNodeByName(const wxXmlNode *parent, const wxString &tagName, const wxString &name);
/// Find the last child node of parent with a given name. NULL if no childs exist
/// \param parent the parent node whom to be searched
/// \param name the element's tag name
static wxXmlNode *FindLastByTagName(const wxXmlNode *parent, const wxString &tagName);
/**
* update node property. If multiple properties with the same name exist, this function updates
* the first occurance
* \param node
* \param name property name
* \param value new value to set
*/
static void UpdateProperty(wxXmlNode *node, const wxString &name, const wxString &value);
/**
* Find the first child node of parent with a given name. NULL if no childs exist
* \param the parent node whom to be searched
* \param the element's tag name
*/
static wxXmlNode *FindFirstByTagName(const wxXmlNode *parent, const wxString &tagName);
/**
* Set the content of node. This function replaces any existing content of node
* \param node
* \param text content
*/
static void SetNodeContent(wxXmlNode *node, const wxString &text);
/**
* Read string property from the given node
* \param propName the property name
* \param defaultValue default value to return if no property exist
*/
static wxString ReadString(wxXmlNode *node, const wxString &propName, const wxString &defaultValue = wxEmptyString);
/**
* Read long property from the given node
* \param propName the property name
* \param defaultValue default value to return if no property exist
*/
static long ReadLong(wxXmlNode *node, const wxString &propName, long defaultValue = -1);
/**
* Read a boolean property from the given node
* \param propName the property name
* \param defaultValue default value to return if no property exist
*/
static bool ReadBool(wxXmlNode *node, const wxString &propName, bool defaultValue = false);
/**
* Remove all children of xml node
* \param node xml node
*/
static void RemoveChildren(wxXmlNode *node);
};
#endif // XMLUTILS_H