2006-04-30 11:37:12 +00:00
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% Name: xmlnode.tex
%% Purpose: wxXmlNode documentation
%% Author: Francesco Montorsi
%% Created: 2006-04-18
%% RCS-ID: $Id$
%% Copyright: (c) 2006 Francesco Montorsi
%% License: wxWindows license
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2006-03-11 13:43:58 +00:00
\section { \class { wxXmlNode} } \label { wxxmlnode}
Represents a node in an XML document. See \helpref { wxXmlDocument} { wxxmldocument} .
2007-07-14 10:07:41 +00:00
Node has a name and may have content and attributes. Most common node types are
{ \tt wxXML\_ TEXT\_ NODE} (name and attributes are irrelevant) and
2007-04-13 01:27:57 +00:00
{ \tt wxXML\_ ELEMENT\_ NODE} (e.g. in { \tt <title>hi</title>} there is an element
with name="title", irrelevant content and one child ({ \tt wxXML\_ TEXT\_ NODE}
2006-03-11 13:43:58 +00:00
with content="hi").
2006-04-30 11:37:12 +00:00
If \texttt { wxUSE\_ UNICODE} is 0, all strings are encoded in the encoding given to
\helpref { wxXmlDocument::Load} { wxxmldocumentload} (default is UTF-8).
2006-03-11 13:43:58 +00:00
\wxheading { Derived from}
No base class
\wxheading { Include files}
<wx/xml/xml.h>
2007-07-28 12:21:03 +00:00
\wxheading { Library}
\helpref { wxXml} { librarieslist}
2006-03-11 13:43:58 +00:00
\wxheading { Constants}
2006-04-30 11:37:12 +00:00
The following are the node types supported by \helpref { wxXmlNode} { wxxmlnode} :
2006-03-11 13:43:58 +00:00
{ \small
\begin { verbatim}
enum wxXmlNodeType
{
wxXML_ ELEMENT_ NODE,
wxXML_ ATTRIBUTE_ NODE,
wxXML_ TEXT_ NODE,
wxXML_ CDATA_ SECTION_ NODE,
wxXML_ ENTITY_ REF_ NODE,
wxXML_ ENTITY_ NODE,
wxXML_ PI_ NODE,
wxXML_ COMMENT_ NODE,
wxXML_ DOCUMENT_ NODE,
wxXML_ DOCUMENT_ TYPE_ NODE,
wxXML_ DOCUMENT_ FRAG_ NODE,
wxXML_ NOTATION_ NODE,
wxXML_ HTML_ DOCUMENT_ NODE
}
\end { verbatim}
}
\wxheading { See also}
2007-07-14 10:07:41 +00:00
\helpref { wxXmlDocument} { wxxmldocument} , \helpref { wxXmlAttribute} { wxxmlattribute}
2006-03-11 13:43:58 +00:00
\latexignore { \rtfignore { \wxheading { Members} } }
\membersection { wxXmlNode::wxXmlNode} \label { wxxmlnodewxxmlnode}
2007-07-14 10:07:41 +00:00
\func { } { wxXmlNode} { \param { wxXmlNode* } { parent} , \param { wxXmlNodeType } { type} , \param { const wxString\& } { name} , \param { const wxString\& } { content = wxEmptyString} , \param { wxXmlAttribute* } { attrs = \NULL } , \param { wxXmlNode* } { next = \NULL } }
2006-03-11 13:43:58 +00:00
\wxheading { Parameters}
2007-04-13 01:27:57 +00:00
\docparam { parent} { The parent node to which append this node instance.
If this argument is \NULL this new node will be { \it floating} and it can be appended later to
another one using the \helpref { AddChild} { wxxmlnodeaddchild} or \helpref { InsertChild} { wxxmlnodeinsertchild}
functions. Otherwise the child is already added to the XML tree by this
constructor and it shouldn't be done again.}
2006-03-11 13:43:58 +00:00
\docparam { type} { One of the wxXmlNodeType enumeration value.}
\docparam { name} { The name of the node. This is the string which appears between angular brackets.}
2007-04-13 01:27:57 +00:00
\docparam { content} { The content of the node. Only meaningful when { \it type} is
{ \tt wxXML\_ TEXT\_ NODE} or { \tt wxXML\_ CDATA\_ SECTION\_ NODE} .}
2007-07-14 10:07:41 +00:00
\docparam { attrs} { If not \NULL , this \helpref { wxXmlAttribute} { wxxmlattribute} object
2007-04-13 01:27:57 +00:00
and its eventual siblings are attached to the node.}
2006-04-30 11:37:12 +00:00
\docparam { next} { If not \NULL , this node and its eventual siblings are attached to
2006-03-11 13:43:58 +00:00
the node.}
2007-04-13 01:27:57 +00:00
Creates this XML node and eventually insert it into an existing XML tree.
2006-03-11 13:43:58 +00:00
\func { } { wxXmlNode} { \param { const wxXmlNode\& } { node} }
Copy constructor. Note that this does NOT copy syblings
2007-04-13 01:27:57 +00:00
and parent pointer, i.e. \helpref { GetParent()} { wxxmlnodegetparent} and
\helpref { GetNext()} { wxxmlnodegetnext} will return \NULL
2006-03-11 13:43:58 +00:00
after using copy ctor and are never unmodified by operator=.
2007-07-14 10:07:41 +00:00
On the other hand, it DOES copy children and attributes.
2006-03-11 13:43:58 +00:00
\func { } { wxXmlNode} { \param { wxXmlNodeType } { type} , \param { const wxString\& } { name} , \param { const wxString\& } { content = wxEmptyString} }
2007-04-13 01:27:57 +00:00
A simplified version of the first constructor form, assuming a \NULL parent.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::\destruct { wxXmlNode} } \label { wxxmlnodedtor}
\func { } { \destruct { wxXmlNode} } { \void }
2007-07-14 10:07:41 +00:00
The virtual destructor. Deletes attached children and attributes.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::AddChild} \label { wxxmlnodeaddchild}
\func { void} { AddChild} { \param { wxXmlNode* } { child} }
Adds the given node as child of this node. To attach a second children to this node, use the
\helpref { SetNext()} { wxxmlnodesetnext} function of the { \it child} node.
2007-07-14 10:07:41 +00:00
\membersection { wxXmlNode::AddAttribute} \label { wxxmlnodeaddattribute}
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\func { void} { AddAttribute} { \param { const wxString\& } { name} , \param { const wxString\& } { value} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Appends a attribute with given { \it name} and { \it value} to the list of attributes for this node.
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\func { void} { AddAttribute} { \param { wxXmlAttribute* } { attr} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Appends given attribute to the list of attributes for this node.
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\membersection { wxXmlNode::DeleteAttribute} \label { wxxmlnodedeleteattribute}
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\func { bool} { DeleteAttribute} { \param { const wxString\& } { name} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Removes the first attributes which has the given { \it name} from the list of attributes for this node.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::GetChildren} \label { wxxmlnodegetchildren}
2006-09-11 11:08:49 +00:00
\constfunc { wxXmlNode*} { GetChildren} { \void }
2006-03-11 13:43:58 +00:00
Returns the first child of this node.
To get a pointer to the second child of this node (if it does exist), use the
\helpref { GetNext()} { wxxmlnodegetnext} function on the returned value.
\membersection { wxXmlNode::GetContent} \label { wxxmlnodegetcontent}
\constfunc { wxString} { GetContent} { \void }
Returns the content of this node. Can be an empty string.
2006-05-28 09:12:42 +00:00
Be aware that for nodes of type \texttt { wxXML\_ ELEMENT\_ NODE} (the most used node type) the
2006-04-30 11:37:12 +00:00
content is an empty string. See \helpref { GetNodeContent()} { wxxmlnodegetnodecontent} for more details.
2006-09-11 11:08:49 +00:00
\membersection { wxXmlNode::GetDepth} \label { wxxmlnodegetdepth}
\constfunc { int} { GetDepth} { \param { wxXmlNode* } { grandparent = NULL} }
Returns the number of nodes which separe this node from { \tt grandparent} .
This function searches only the parents of this node until it finds { \tt grandparent}
or the \NULL node (which is the parent of non-linked nodes or the parent of a
\helpref { wxXmlDocument} { wxxmldocument} 's root node).
2006-04-30 11:37:12 +00:00
\membersection { wxXmlNode::GetNodeContent} \label { wxxmlnodegetnodecontent}
\constfunc { wxString} { GetNodeContent} { \void }
2006-05-28 09:12:42 +00:00
Returns the content of the first child node of type \texttt { wxXML\_ TEXT\_ NODE} or \texttt { wxXML\_ CDATA\_ SECTION\_ NODE} .
2006-04-30 11:37:12 +00:00
This function is very useful since the XML snippet \texttt { ``<tagname>tagcontent</tagname>"} is represented by
expat with the following tag tree:
\begin { verbatim}
wxXML_ ENTITY_ NODE name="tagname", content=""
|-- wxXML_ TEXT_ NODE name="", content="tagcontent"
\end { verbatim}
or eventually:
\begin { verbatim}
wxXML_ ENTITY_ NODE name="tagname", content=""
|-- wxXML_ CDATA_ SECTION_ NODE name="", content="tagcontent"
\end { verbatim}
2006-05-28 09:12:42 +00:00
An empty string is returned if the node has no children of type \texttt { wxXML\_ TEXT\_ NODE} or \texttt { wxXML\_ CDATA\_ SECTION\_ NODE} , or if the content of the first child of such types is empty.
2006-04-30 11:37:12 +00:00
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::GetName} \label { wxxmlnodegetname}
\constfunc { wxString} { GetName} { \void }
Returns the name of this node. Can be an empty string (e.g. for nodes of type { \tt wxXML\_ TEXT\_ NODE} or { \tt wxXML\_ CDATA\_ SECTION\_ NODE} ).
\membersection { wxXmlNode::GetNext} \label { wxxmlnodegetnext}
\constfunc { wxXmlNode*} { GetNext} { \void }
2006-04-30 11:37:12 +00:00
Returns a pointer to the sibling of this node or \NULL if there are no siblings.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::GetParent} \label { wxxmlnodegetparent}
\constfunc { wxXmlNode*} { GetParent} { \void }
2006-04-30 11:37:12 +00:00
Returns a pointer to the parent of this node or \NULL if this node has no parent.
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\membersection { wxXmlNode::GetAttribute} \label { wxxmlnodegetattribute}
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\constfunc { bool} { GetAttribute} { \param { const wxString\& } { attrName} , \param { wxString* } { value} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Returns \true if a attribute named { \it attrName} could be found.
If the { \it value} pointer is not \NULL , the value of that attribute is saved there.
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\constfunc { wxString} { GetAttribute} { \param { const wxString\& } { attrName} , \param { const wxString\& } { defaultVal} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Returns the value of the attribute named { \it attrName} if it does exist.
2006-03-11 13:43:58 +00:00
If it does not exist, the { \it defaultVal} is returned.
2007-07-14 10:07:41 +00:00
\membersection { wxXmlNode::GetAttributes} \label { wxxmlnodegetattributes}
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\constfunc { wxXmlAttribute *} { GetAttributes} { \void }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Return a pointer to the first attribute of this node.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::GetType} \label { wxxmlnodegettype}
\constfunc { wxXmlNodeType} { GetType} { \void }
Returns the type of this node.
2007-07-14 10:07:41 +00:00
\membersection { wxXmlNode::HasAttribute} \label { wxxmlnodehasattribute}
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\constfunc { bool} { HasAttribute} { \param { const wxString\& } { attrName} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Returns \true if this node has a attribute named { \it attrName} .
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::InsertChild} \label { wxxmlnodeinsertchild}
2006-09-09 11:32:10 +00:00
\func { bool} { InsertChild} { \param { wxXmlNode* } { child} , \param { wxXmlNode* } { before\_ node} }
2006-03-11 13:43:58 +00:00
Inserts the { \it child} node after { \it before\_ node} in the children list.
2006-09-09 11:32:10 +00:00
If { \it before\_ node} is \NULL , then { \it child} is prepended to the list of children and
becomes the first child of this node.
Returns \true if { \it before\_ node} has been found and the { \it child} node has been inserted.
2006-03-11 13:43:58 +00:00
2006-09-11 11:08:49 +00:00
\membersection { wxXmlNode::IsWhitespaceOnly} \label { wxxmlnodecontainsiswhitespaceonly}
\constfunc { bool} { IsWhitespaceOnly} { \void }
Returns \true if the content of this node is a string containing only whitespaces (spaces,
tabs, new lines, etc). Note that this function is locale-independent since the parsing of XML
documents must always produce the exact same tree regardless of the locale it runs under.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::RemoveChild} \label { wxxmlnoderemovechild}
\func { bool} { RemoveChild} { \param { wxXmlNode* } { child} }
Removes the given node from the children list. Returns \true if the node was found and removed
or \false if the node could not be found.
2006-10-08 15:49:36 +00:00
Note that the caller is reponsible for deleting the removed node in order to avoid memory leaks.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::SetChildren} \label { wxxmlnodesetchildren}
\func { void} { SetChildren} { \param { wxXmlNode* } { child} }
Sets as first child the given node. The caller is responsible to delete any previously present
children node.
\membersection { wxXmlNode::SetContent} \label { wxxmlnodesetcontent}
\func { void} { SetContent} { \param { const wxString\& } { con} }
Sets the content of this node.
\membersection { wxXmlNode::SetName} \label { wxxmlnodesetname}
\func { void} { SetName} { \param { const wxString\& } { name} }
Sets the name of this node.
\membersection { wxXmlNode::SetNext} \label { wxxmlnodesetnext}
\func { void} { SetNext} { \param { wxXmlNode* } { next} }
Sets as sibling the given node. The caller is responsible to delete any previously present
sibling node.
\membersection { wxXmlNode::SetParent} \label { wxxmlnodesetparent}
\func { void} { SetParent} { \param { wxXmlNode* } { parent} }
Sets as parent the given node. The caller is responsible to delete any previously present
parent node.
2007-07-14 10:07:41 +00:00
\membersection { wxXmlNode::SetAttributes} \label { wxxmlnodesetattributes}
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
\func { void} { SetAttributes} { \param { wxXmlAttribute* } { attr} }
2006-03-11 13:43:58 +00:00
2007-07-14 10:07:41 +00:00
Sets as first attribute the given wxXmlAttribute object.
The caller is responsible to delete any previously present attributes attached to this node.
2006-03-11 13:43:58 +00:00
\membersection { wxXmlNode::SetType} \label { wxxmlnodesettype}
\func { void} { SetType} { \param { wxXmlNodeType } { type} }
Sets the type of this node.
\membersection { wxXmlNode::operator=} \label { wxxmlnodeoperatorassign}
2006-04-30 11:37:12 +00:00
\func { wxXmlNode\& } { operator=} { \param { const wxXmlNode\& } { node} }
2006-03-11 13:43:58 +00:00
See the copy constructor for more info.