FEDRA emulsion software from the OPERA Collaboration
TiXmlNode Class Referenceabstract

#include <tinyxml.h>

Inheritance diagram for TiXmlNode:
Collaboration diagram for TiXmlNode:

Public Types

enum  NodeType {
  TINYXML_DOCUMENT , TINYXML_ELEMENT , TINYXML_COMMENT , TINYXML_UNKNOWN ,
  TINYXML_TEXT , TINYXML_DECLARATION , TINYXML_TYPECOUNT
}
 
- Public Types inherited from TiXmlBase
enum  {
  TIXML_NO_ERROR = 0 , TIXML_ERROR , TIXML_ERROR_OPENING_FILE , TIXML_ERROR_PARSING_ELEMENT ,
  TIXML_ERROR_FAILED_TO_READ_ELEMENT_NAME , TIXML_ERROR_READING_ELEMENT_VALUE , TIXML_ERROR_READING_ATTRIBUTES , TIXML_ERROR_PARSING_EMPTY ,
  TIXML_ERROR_READING_END_TAG , TIXML_ERROR_PARSING_UNKNOWN , TIXML_ERROR_PARSING_COMMENT , TIXML_ERROR_PARSING_DECLARATION ,
  TIXML_ERROR_DOCUMENT_EMPTY , TIXML_ERROR_EMBEDDED_NULL , TIXML_ERROR_PARSING_CDATA , TIXML_ERROR_DOCUMENT_TOP_ONLY ,
  TIXML_ERROR_STRING_COUNT
}
 

Public Member Functions

virtual bool Accept (TiXmlVisitor *visitor) const =0
 
void Clear ()
 Delete all the children of this node. Does not affect 'this'. More...
 
virtual TiXmlNodeClone () const =0
 
TiXmlNodeFirstChild ()
 
const TiXmlNodeFirstChild () const
 The first child of this node. Will be null if there are no children. More...
 
TiXmlNodeFirstChild (const char *_value)
 The first child of this node with the matching 'value'. Will be null if none found. More...
 
const TiXmlNodeFirstChild (const char *value) const
 
TiXmlElementFirstChildElement ()
 
const TiXmlElementFirstChildElement () const
 Convenience function to get through elements. More...
 
TiXmlElementFirstChildElement (const char *_value)
 
const TiXmlElementFirstChildElement (const char *_value) const
 Convenience function to get through elements. More...
 
TiXmlDocumentGetDocument ()
 
const TiXmlDocumentGetDocument () const
 
TiXmlNodeInsertAfterChild (TiXmlNode *afterThis, const TiXmlNode &addThis)
 
TiXmlNodeInsertBeforeChild (TiXmlNode *beforeThis, const TiXmlNode &addThis)
 
TiXmlNodeInsertEndChild (const TiXmlNode &addThis)
 
TiXmlNodeIterateChildren (const char *_value, const TiXmlNode *previous)
 
const TiXmlNodeIterateChildren (const char *value, const TiXmlNode *previous) const
 This flavor of IterateChildren searches for children with a particular 'value'. More...
 
TiXmlNodeIterateChildren (const TiXmlNode *previous)
 
const TiXmlNodeIterateChildren (const TiXmlNode *previous) const
 
TiXmlNodeLastChild ()
 The last child of this node. Will be null if there are no children. More...
 
const TiXmlNodeLastChild () const
 
TiXmlNodeLastChild (const char *_value)
 The last child of this node matching 'value'. Will be null if there are no children. More...
 
const TiXmlNodeLastChild (const char *value) const
 
TiXmlNodeLinkEndChild (TiXmlNode *addThis)
 
TiXmlNodeNextSibling ()
 
const TiXmlNodeNextSibling () const
 Navigate to a sibling node. More...
 
const TiXmlNodeNextSibling (const char *) const
 Navigate to a sibling node with the given 'value'. More...
 
TiXmlNodeNextSibling (const char *_next)
 
TiXmlElementNextSiblingElement ()
 
const TiXmlElementNextSiblingElement () const
 
const TiXmlElementNextSiblingElement (const char *) const
 
TiXmlElementNextSiblingElement (const char *_next)
 
bool NoChildren () const
 Returns true if this node has no children. More...
 
TiXmlNodeParent ()
 One step up the DOM. More...
 
const TiXmlNodeParent () const
 
TiXmlNodePreviousSibling ()
 
const TiXmlNodePreviousSibling () const
 Navigate to a sibling node. More...
 
const TiXmlNodePreviousSibling (const char *) const
 Navigate to a sibling node. More...
 
TiXmlNodePreviousSibling (const char *_prev)
 
bool RemoveChild (TiXmlNode *removeThis)
 Delete a child of this node. More...
 
TiXmlNodeReplaceChild (TiXmlNode *replaceThis, const TiXmlNode &withThis)
 
void SetValue (const char *_value)
 
virtual TiXmlCommentToComment ()
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual const TiXmlCommentToComment () const
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual TiXmlDeclarationToDeclaration ()
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual const TiXmlDeclarationToDeclaration () const
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual TiXmlDocumentToDocument ()
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual const TiXmlDocumentToDocument () const
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual TiXmlElementToElement ()
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual const TiXmlElementToElement () const
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual TiXmlTextToText ()
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual const TiXmlTextToText () const
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual TiXmlUnknownToUnknown ()
 Cast to a more defined type. Will return null if not of the requested type. More...
 
virtual const TiXmlUnknownToUnknown () const
 Cast to a more defined type. Will return null if not of the requested type. More...
 
int Type () const
 
const char * Value () const
 
const TIXML_STRINGValueTStr () const
 
virtual ~TiXmlNode ()
 
- Public Member Functions inherited from TiXmlBase
int Column () const
 See Row() More...
 
voidGetUserData ()
 Get a pointer to arbitrary user data. More...
 
const voidGetUserData () const
 Get a pointer to arbitrary user data. More...
 
virtual const char * Parse (const char *p, TiXmlParsingData *data, TiXmlEncoding encoding)=0
 
virtual void Print (FILE *cfile, int depth) const =0
 
int Row () const
 
void SetUserData (void *user)
 Set a pointer to arbitrary user data. More...
 
 TiXmlBase ()
 
virtual ~TiXmlBase ()
 

Protected Member Functions

void CopyTo (TiXmlNode *target) const
 
TiXmlNodeIdentify (const char *start, TiXmlEncoding encoding)
 
 TiXmlNode (NodeType _type)
 

Protected Attributes

TiXmlNodefirstChild
 
TiXmlNodelastChild
 
TiXmlNodenext
 
TiXmlNodeparent
 
TiXmlNodeprev
 
NodeType type
 
TIXML_STRING value
 
- Protected Attributes inherited from TiXmlBase
TiXmlCursor location
 
voiduserData
 Field containing a generic user pointer. More...
 

Private Member Functions

void operator= (const TiXmlNode &base)
 
 TiXmlNode (const TiXmlNode &)
 

Friends

class TiXmlDocument
 
class TiXmlElement
 

Additional Inherited Members

- Static Public Member Functions inherited from TiXmlBase
static void EncodeString (const TIXML_STRING &str, TIXML_STRING *out)
 
static bool IsWhiteSpaceCondensed ()
 Return the current white space setting. More...
 
static void SetCondenseWhiteSpace (bool condense)
 
- Static Public Attributes inherited from TiXmlBase
static const int utf8ByteTable [256]
 
- Static Protected Member Functions inherited from TiXmlBase
static void ConvertUTF32ToUTF8 (unsigned long input, char *output, int *length)
 
static const char * GetChar (const char *p, char *_value, int *length, TiXmlEncoding encoding)
 
static const char * GetEntity (const char *in, char *value, int *length, TiXmlEncoding encoding)
 
static int IsAlpha (unsigned char anyByte, TiXmlEncoding encoding)
 
static int IsAlphaNum (unsigned char anyByte, TiXmlEncoding encoding)
 
static bool IsWhiteSpace (char c)
 
static bool IsWhiteSpace (int c)
 
static const char * ReadName (const char *p, TIXML_STRING *name, TiXmlEncoding encoding)
 
static const char * ReadText (const char *in, TIXML_STRING *text, bool ignoreWhiteSpace, const char *endTag, bool ignoreCase, TiXmlEncoding encoding)
 
static const char * SkipWhiteSpace (const char *, TiXmlEncoding encoding)
 
static bool StringEqual (const char *p, const char *endTag, bool ignoreCase, TiXmlEncoding encoding)
 
static int ToLower (int v, TiXmlEncoding encoding)
 
- Static Protected Attributes inherited from TiXmlBase
static const char * errorString [TIXML_ERROR_STRING_COUNT]
 

Detailed Description

The parent class for everything in the Document Object Model. (Except for attributes). Nodes have siblings, a parent, and children. A node can be in a document, or stand on its own. The type of a TiXmlNode can be queried, and it can be cast to its more defined type.

Member Enumeration Documentation

◆ NodeType

The types of XML nodes supported by TinyXml. (All the unsupported types are picked up by UNKNOWN.)

Enumerator
TINYXML_DOCUMENT 
TINYXML_ELEMENT 
TINYXML_COMMENT 
TINYXML_UNKNOWN 
TINYXML_TEXT 
TINYXML_DECLARATION 
TINYXML_TYPECOUNT 
463 {
471 };
@ TINYXML_DECLARATION
Definition: tinyxml.h:469
@ TINYXML_UNKNOWN
Definition: tinyxml.h:467
@ TINYXML_COMMENT
Definition: tinyxml.h:466
@ TINYXML_DOCUMENT
Definition: tinyxml.h:464
@ TINYXML_TYPECOUNT
Definition: tinyxml.h:470
@ TINYXML_ELEMENT
Definition: tinyxml.h:465
@ TINYXML_TEXT
Definition: tinyxml.h:468

Constructor & Destructor Documentation

◆ ~TiXmlNode()

TiXmlNode::~TiXmlNode ( )
virtual
148{
149 TiXmlNode* node = firstChild;
150 TiXmlNode* temp = 0;
151
152 while ( node )
153 {
154 temp = node;
155 node = node->next;
156 delete temp;
157 }
158}
Definition: tinyxml.h:424
TiXmlNode * next
Definition: tinyxml.h:764
TiXmlNode * firstChild
Definition: tinyxml.h:758

◆ TiXmlNode() [1/2]

TiXmlNode::TiXmlNode ( NodeType  _type)
protected
136 : TiXmlBase()
137{
138 parent = 0;
139 type = _type;
140 firstChild = 0;
141 lastChild = 0;
142 prev = 0;
143 next = 0;
144}
TiXmlBase()
Definition: tinyxml.h:201
NodeType type
Definition: tinyxml.h:756
TiXmlNode * lastChild
Definition: tinyxml.h:759
TiXmlNode * parent
Definition: tinyxml.h:755
TiXmlNode * prev
Definition: tinyxml.h:763

◆ TiXmlNode() [2/2]

TiXmlNode::TiXmlNode ( const TiXmlNode )
private

Member Function Documentation

◆ Accept()

virtual bool TiXmlNode::Accept ( TiXmlVisitor visitor) const
pure virtual

Accept a hierchical visit the nodes in the TinyXML DOM. Every node in the XML tree will be conditionally visited and the host will be called back via the TiXmlVisitor interface.

This is essentially a SAX interface for TinyXML. (Note however it doesn't re-parse the XML for the callbacks, so the performance of TinyXML is unchanged by using this interface versus any other.)

The interface has been based on ideas from:

Which are both good references for "visiting".

An example of using Accept():

TiXmlPrinter printer;
tinyxmlDoc.Accept( &printer );
const char* xmlcstr = printer.CStr();

Implemented in TiXmlText, TiXmlUnknown, TiXmlDocument, TiXmlElement, TiXmlComment, and TiXmlDeclaration.

◆ Clear()

void TiXmlNode::Clear ( )

Delete all the children of this node. Does not affect 'this'.

170{
171 TiXmlNode* node = firstChild;
172 TiXmlNode* temp = 0;
173
174 while ( node )
175 {
176 temp = node;
177 node = node->next;
178 delete temp;
179 }
180
181 firstChild = 0;
182 lastChild = 0;
183}

◆ Clone()

virtual TiXmlNode * TiXmlNode::Clone ( ) const
pure virtual

Create an exact duplicate of this node and return it. The memory must be deleted by the caller.

Implemented in TiXmlElement, TiXmlComment, TiXmlText, TiXmlDeclaration, TiXmlUnknown, and TiXmlDocument.

◆ CopyTo()

void TiXmlNode::CopyTo ( TiXmlNode target) const
protected
162{
163 target->SetValue (value.c_str() );
164 target->userData = userData;
165 target->location = location;
166}
TiXmlCursor location
Definition: tinyxml.h:373
void * userData
Field containing a generic user pointer.
Definition: tinyxml.h:376
void SetValue(const char *_value)
Definition: tinyxml.h:508
TIXML_STRING value
Definition: tinyxml.h:761

◆ FirstChild() [1/4]

TiXmlNode * TiXmlNode::FirstChild ( )
inline
523{ return firstChild; }

◆ FirstChild() [2/4]

const TiXmlNode * TiXmlNode::FirstChild ( ) const
inline

The first child of this node. Will be null if there are no children.

◆ FirstChild() [3/4]

TiXmlNode * TiXmlNode::FirstChild ( const char *  _value)
inline

The first child of this node with the matching 'value'. Will be null if none found.

526 {
527 // Call through to the const version - safe since nothing is changed. Exiting syntax: cast this to a const (always safe)
528 // call the method, cast the return back to non-const.
529 return const_cast< TiXmlNode* > ((const_cast< const TiXmlNode* >(this))->FirstChild( _value ));
530 }

◆ FirstChild() [4/4]

const TiXmlNode * TiXmlNode::FirstChild ( const char *  value) const

The first child of this node with the matching 'value'. Will be null if none found.

362{
363 const TiXmlNode* node;
364 for ( node = firstChild; node; node = node->next )
365 {
366 if ( strcmp( node->Value(), _value ) == 0 )
367 return node;
368 }
369 return 0;
370}
const char * Value() const
Definition: tinyxml.h:487

◆ FirstChildElement() [1/4]

TiXmlElement * TiXmlNode::FirstChildElement ( )
inline
665 {
666 return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->FirstChildElement() );
667 }
Definition: tinyxml.h:941

◆ FirstChildElement() [2/4]

const TiXmlElement * TiXmlNode::FirstChildElement ( ) const

Convenience function to get through elements.

453{
454 const TiXmlNode* node;
455
456 for ( node = FirstChild();
457 node;
458 node = node->NextSibling() )
459 {
460 if ( node->ToElement() )
461 return node->ToElement();
462 }
463 return 0;
464}
const TiXmlNode * NextSibling() const
Navigate to a sibling node.
Definition: tinyxml.h:631
virtual const TiXmlElement * ToElement() const
Cast to a more defined type. Will return null if not of the requested type.
Definition: tinyxml.h:698
const TiXmlNode * FirstChild() const
The first child of this node. Will be null if there are no children.
Definition: tinyxml.h:522

◆ FirstChildElement() [3/4]

TiXmlElement * TiXmlNode::FirstChildElement ( const char *  _value)
inline
671 {
672 return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->FirstChildElement( _value ) );
673 }

◆ FirstChildElement() [4/4]

const TiXmlElement * TiXmlNode::FirstChildElement ( const char *  _value) const

Convenience function to get through elements.

468{
469 const TiXmlNode* node;
470
471 for ( node = FirstChild( _value );
472 node;
473 node = node->NextSibling( _value ) )
474 {
475 if ( node->ToElement() )
476 return node->ToElement();
477 }
478 return 0;
479}

◆ GetDocument() [1/2]

TiXmlDocument * TiXmlNode::GetDocument ( )
inline
690 {
691 return const_cast< TiXmlDocument* >( (const_cast< const TiXmlNode* >(this))->GetDocument() );
692 }
Definition: tinyxml.h:1394

◆ GetDocument() [2/2]

const TiXmlDocument * TiXmlNode::GetDocument ( ) const

Return a pointer to the Document this node lives in. Returns null if not in a document.

513{
514 const TiXmlNode* node;
515
516 for( node = this; node; node = node->parent )
517 {
518 if ( node->ToDocument() )
519 return node->ToDocument();
520 }
521 return 0;
522}
virtual const TiXmlDocument * ToDocument() const
Cast to a more defined type. Will return null if not of the requested type.
Definition: tinyxml.h:697

◆ Identify()

TiXmlNode * TiXmlNode::Identify ( const char *  start,
TiXmlEncoding  encoding 
)
protected
819{
820 TiXmlNode* returnNode = 0;
821
822 p = SkipWhiteSpace( p, encoding );
823 if( !p || !*p || *p != '<' )
824 {
825 return 0;
826 }
827
828 p = SkipWhiteSpace( p, encoding );
829
830 if ( !p || !*p )
831 {
832 return 0;
833 }
834
835 // What is this thing?
836 // - Elements start with a letter or underscore, but xml is reserved.
837 // - Comments: <!--
838 // - Decleration: <?xml
839 // - Everthing else is unknown to tinyxml.
840 //
841
842 const char* xmlHeader = { "<?xml" };
843 const char* commentHeader = { "<!--" };
844 const char* dtdHeader = { "<!" };
845 const char* cdataHeader = { "<![CDATA[" };
846
847 if ( StringEqual( p, xmlHeader, true, encoding ) )
848 {
849 #ifdef DEBUG_PARSER
850 TIXML_LOG( "XML parsing Declaration\n" );
851 #endif
852 returnNode = new TiXmlDeclaration();
853 }
854 else if ( StringEqual( p, commentHeader, false, encoding ) )
855 {
856 #ifdef DEBUG_PARSER
857 TIXML_LOG( "XML parsing Comment\n" );
858 #endif
859 returnNode = new TiXmlComment();
860 }
861 else if ( StringEqual( p, cdataHeader, false, encoding ) )
862 {
863 #ifdef DEBUG_PARSER
864 TIXML_LOG( "XML parsing CDATA\n" );
865 #endif
866 TiXmlText* text = new TiXmlText( "" );
867 text->SetCDATA( true );
868 returnNode = text;
869 }
870 else if ( StringEqual( p, dtdHeader, false, encoding ) )
871 {
872 #ifdef DEBUG_PARSER
873 TIXML_LOG( "XML parsing Unknown(1)\n" );
874 #endif
875 returnNode = new TiXmlUnknown();
876 }
877 else if ( IsAlpha( *(p+1), encoding )
878 || *(p+1) == '_' )
879 {
880 #ifdef DEBUG_PARSER
881 TIXML_LOG( "XML parsing Element\n" );
882 #endif
883 returnNode = new TiXmlElement( "" );
884 }
885 else
886 {
887 #ifdef DEBUG_PARSER
888 TIXML_LOG( "XML parsing Unknown(2)\n" );
889 #endif
890 returnNode = new TiXmlUnknown();
891 }
892
893 if ( returnNode )
894 {
895 // Set the parent, so it can report errors
896 returnNode->parent = this;
897 }
898 return returnNode;
899}
TText * text
Definition: Canv_SYSTEMATICS_ALLCOMBINED__RMSEnergy__vs__Energy__ELECTRON.C:164
static bool StringEqual(const char *p, const char *endTag, bool ignoreCase, TiXmlEncoding encoding)
Definition: tinyxmlparser.cpp:534
static const char * SkipWhiteSpace(const char *, TiXmlEncoding encoding)
Definition: tinyxmlparser.cpp:314
static int IsAlpha(unsigned char anyByte, TiXmlEncoding encoding)
Definition: tinyxmlparser.cpp:129
Definition: tinyxml.h:1163
Definition: tinyxml.h:1286
friend class TiXmlElement
Definition: tinyxml.h:426
Definition: tinyxml.h:1213
Definition: tinyxml.h:1355
p
Definition: testBGReduction_AllMethods.C:8

◆ InsertAfterChild()

TiXmlNode * TiXmlNode::InsertAfterChild ( TiXmlNode afterThis,
const TiXmlNode addThis 
)

Add a new node related to this. Adds a child after the specified child. Returns a pointer to the new object or NULL if an error occured.

264{
265 if ( !afterThis || afterThis->parent != this ) {
266 return 0;
267 }
268 if ( addThis.Type() == TiXmlNode::TINYXML_DOCUMENT )
269 {
270 if ( GetDocument() )
272 return 0;
273 }
274
275 TiXmlNode* node = addThis.Clone();
276 if ( !node )
277 return 0;
278 node->parent = this;
279
280 node->prev = afterThis;
281 node->next = afterThis->next;
282 if ( afterThis->next )
283 {
284 afterThis->next->prev = node;
285 }
286 else
287 {
288 assert( lastChild == afterThis );
289 lastChild = node;
290 }
291 afterThis->next = node;
292 return node;
293}
@ TIXML_ERROR_DOCUMENT_TOP_ONLY
Definition: tinyxml.h:281
void SetError(int err, const char *errorLocation, TiXmlParsingData *prevData, TiXmlEncoding encoding)
Definition: tinyxmlparser.cpp:798
int Type() const
Definition: tinyxml.h:684
virtual TiXmlNode * Clone() const =0
const TiXmlDocument * GetDocument() const
Definition: tinyxml.cpp:512
@ TIXML_ENCODING_UNKNOWN
Definition: tinyxml.h:165

◆ InsertBeforeChild()

TiXmlNode * TiXmlNode::InsertBeforeChild ( TiXmlNode beforeThis,
const TiXmlNode addThis 
)

Add a new node related to this. Adds a child before the specified child. Returns a pointer to the new object or NULL if an error occured.

231{
232 if ( !beforeThis || beforeThis->parent != this ) {
233 return 0;
234 }
235 if ( addThis.Type() == TiXmlNode::TINYXML_DOCUMENT )
236 {
237 if ( GetDocument() )
239 return 0;
240 }
241
242 TiXmlNode* node = addThis.Clone();
243 if ( !node )
244 return 0;
245 node->parent = this;
246
247 node->next = beforeThis;
248 node->prev = beforeThis->prev;
249 if ( beforeThis->prev )
250 {
251 beforeThis->prev->next = node;
252 }
253 else
254 {
255 assert( firstChild == beforeThis );
256 firstChild = node;
257 }
258 beforeThis->prev = node;
259 return node;
260}

◆ InsertEndChild()

TiXmlNode * TiXmlNode::InsertEndChild ( const TiXmlNode addThis)

Add a new node related to this. Adds a child past the LastChild. Returns a pointer to the new object or NULL if an error occured.

215{
216 if ( addThis.Type() == TiXmlNode::TINYXML_DOCUMENT )
217 {
218 if ( GetDocument() )
220 return 0;
221 }
222 TiXmlNode* node = addThis.Clone();
223 if ( !node )
224 return 0;
225
226 return LinkEndChild( node );
227}
TiXmlNode * LinkEndChild(TiXmlNode *addThis)
Definition: tinyxml.cpp:186

◆ IterateChildren() [1/4]

TiXmlNode * TiXmlNode::IterateChildren ( const char *  _value,
const TiXmlNode previous 
)
inline
569 {
570 return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->IterateChildren( _value, previous ) );
571 }

◆ IterateChildren() [2/4]

const TiXmlNode * TiXmlNode::IterateChildren ( const char *  value,
const TiXmlNode previous 
) const

This flavor of IterateChildren searches for children with a particular 'value'.

400{
401 if ( !previous )
402 {
403 return FirstChild( val );
404 }
405 else
406 {
407 assert( previous->parent == this );
408 return previous->NextSibling( val );
409 }
410}

◆ IterateChildren() [3/4]

TiXmlNode * TiXmlNode::IterateChildren ( const TiXmlNode previous)
inline
563 {
564 return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->IterateChildren( previous ) );
565 }

◆ IterateChildren() [4/4]

const TiXmlNode * TiXmlNode::IterateChildren ( const TiXmlNode previous) const

An alternate way to walk the children of a node. One way to iterate over nodes is:

    for( child = parent->FirstChild(); child; child = child->NextSibling() )

IterateChildren does the same thing with the syntax:

    child = 0;
    while( child = parent->IterateChildren( child ) )

IterateChildren takes the previous child as input and finds the next one. If the previous child is null, it returns the first. IterateChildren will return null when done.

386{
387 if ( !previous )
388 {
389 return FirstChild();
390 }
391 else
392 {
393 assert( previous->parent == this );
394 return previous->NextSibling();
395 }
396}

◆ LastChild() [1/4]

TiXmlNode * TiXmlNode::LastChild ( )
inline

The last child of this node. Will be null if there are no children.

532{ return lastChild; }

◆ LastChild() [2/4]

const TiXmlNode * TiXmlNode::LastChild ( ) const
inline
531{ return lastChild; }

◆ LastChild() [3/4]

TiXmlNode * TiXmlNode::LastChild ( const char *  _value)
inline

The last child of this node matching 'value'. Will be null if there are no children.

535 {
536 return const_cast< TiXmlNode* > ((const_cast< const TiXmlNode* >(this))->LastChild( _value ));
537 }

◆ LastChild() [4/4]

const TiXmlNode * TiXmlNode::LastChild ( const char *  value) const
374{
375 const TiXmlNode* node;
376 for ( node = lastChild; node; node = node->prev )
377 {
378 if ( strcmp( node->Value(), _value ) == 0 )
379 return node;
380 }
381 return 0;
382}

◆ LinkEndChild()

TiXmlNode * TiXmlNode::LinkEndChild ( TiXmlNode addThis)

Add a new node related to this. Adds a child past the LastChild.

NOTE: the node to be added is passed by pointer, and will be henceforth owned (and deleted) by tinyXml. This method is efficient and avoids an extra copy, but should be used with care as it uses a different memory model than the other insert functions.

See also
InsertEndChild
187{
188 assert( node->parent == 0 || node->parent == this );
189 assert( node->GetDocument() == 0 || node->GetDocument() == this->GetDocument() );
190
191 if ( node->Type() == TiXmlNode::TINYXML_DOCUMENT )
192 {
193 delete node;
194 if ( GetDocument() )
196 return 0;
197 }
198
199 node->parent = this;
200
201 node->prev = lastChild;
202 node->next = 0;
203
204 if ( lastChild )
205 lastChild->next = node;
206 else
207 firstChild = node; // it was an empty list.
208
209 lastChild = node;
210 return node;
211}

◆ NextSibling() [1/4]

TiXmlNode * TiXmlNode::NextSibling ( )
inline
632{ return next; }

◆ NextSibling() [2/4]

const TiXmlNode * TiXmlNode::NextSibling ( ) const
inline

Navigate to a sibling node.

631{ return next; }

◆ NextSibling() [3/4]

const TiXmlNode * TiXmlNode::NextSibling ( const char *  _value) const

Navigate to a sibling node with the given 'value'.

414{
415 const TiXmlNode* node;
416 for ( node = next; node; node = node->next )
417 {
418 if ( strcmp( node->Value(), _value ) == 0 )
419 return node;
420 }
421 return 0;
422}

◆ NextSibling() [4/4]

TiXmlNode * TiXmlNode::NextSibling ( const char *  _next)
inline
636 {
637 return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->NextSibling( _next ) );
638 }

◆ NextSiblingElement() [1/4]

TiXmlElement * TiXmlNode::NextSiblingElement ( )
inline
645 {
646 return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->NextSiblingElement() );
647 }

◆ NextSiblingElement() [2/4]

const TiXmlElement * TiXmlNode::NextSiblingElement ( ) const

Convenience function to get through elements. Calls NextSibling and ToElement. Will skip all non-Element nodes. Returns 0 if there is not another element.

483{
484 const TiXmlNode* node;
485
486 for ( node = NextSibling();
487 node;
488 node = node->NextSibling() )
489 {
490 if ( node->ToElement() )
491 return node->ToElement();
492 }
493 return 0;
494}

◆ NextSiblingElement() [3/4]

const TiXmlElement * TiXmlNode::NextSiblingElement ( const char *  _value) const

Convenience function to get through elements. Calls NextSibling and ToElement. Will skip all non-Element nodes. Returns 0 if there is not another element.

498{
499 const TiXmlNode* node;
500
501 for ( node = NextSibling( _value );
502 node;
503 node = node->NextSibling( _value ) )
504 {
505 if ( node->ToElement() )
506 return node->ToElement();
507 }
508 return 0;
509}

◆ NextSiblingElement() [4/4]

TiXmlElement * TiXmlNode::NextSiblingElement ( const char *  _next)
inline
654 {
655 return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->NextSiblingElement( _next ) );
656 }

◆ NoChildren()

bool TiXmlNode::NoChildren ( ) const
inline

Returns true if this node has no children.

695{ return !firstChild; }

◆ operator=()

void TiXmlNode::operator= ( const TiXmlNode base)
private

◆ Parent() [1/2]

TiXmlNode * TiXmlNode::Parent ( )
inline

One step up the DOM.

519{ return parent; }

◆ Parent() [2/2]

const TiXmlNode * TiXmlNode::Parent ( ) const
inline
520{ return parent; }

◆ PreviousSibling() [1/4]

TiXmlNode * TiXmlNode::PreviousSibling ( )
inline
615{ return prev; }

◆ PreviousSibling() [2/4]

const TiXmlNode * TiXmlNode::PreviousSibling ( ) const
inline

Navigate to a sibling node.

614{ return prev; }

◆ PreviousSibling() [3/4]

const TiXmlNode * TiXmlNode::PreviousSibling ( const char *  _value) const

Navigate to a sibling node.

426{
427 const TiXmlNode* node;
428 for ( node = prev; node; node = node->prev )
429 {
430 if ( strcmp( node->Value(), _value ) == 0 )
431 return node;
432 }
433 return 0;
434}

◆ PreviousSibling() [4/4]

TiXmlNode * TiXmlNode::PreviousSibling ( const char *  _prev)
inline
619 {
620 return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->PreviousSibling( _prev ) );
621 }

◆ RemoveChild()

bool TiXmlNode::RemoveChild ( TiXmlNode removeThis)

Delete a child of this node.

336{
337 if ( !removeThis ) {
338 return false;
339 }
340
341 if ( removeThis->parent != this )
342 {
343 assert( 0 );
344 return false;
345 }
346
347 if ( removeThis->next )
348 removeThis->next->prev = removeThis->prev;
349 else
350 lastChild = removeThis->prev;
351
352 if ( removeThis->prev )
353 removeThis->prev->next = removeThis->next;
354 else
355 firstChild = removeThis->next;
356
357 delete removeThis;
358 return true;
359}

◆ ReplaceChild()

TiXmlNode * TiXmlNode::ReplaceChild ( TiXmlNode replaceThis,
const TiXmlNode withThis 
)

Replace a child of this node. Returns a pointer to the new object or NULL if an error occured.

297{
298 if ( !replaceThis )
299 return 0;
300
301 if ( replaceThis->parent != this )
302 return 0;
303
304 if ( withThis.ToDocument() ) {
305 // A document can never be a child. Thanks to Noam.
306 TiXmlDocument* document = GetDocument();
307 if ( document )
309 return 0;
310 }
311
312 TiXmlNode* node = withThis.Clone();
313 if ( !node )
314 return 0;
315
316 node->next = replaceThis->next;
317 node->prev = replaceThis->prev;
318
319 if ( replaceThis->next )
320 replaceThis->next->prev = node;
321 else
322 lastChild = node;
323
324 if ( replaceThis->prev )
325 replaceThis->prev->next = node;
326 else
327 firstChild = node;
328
329 delete replaceThis;
330 node->parent = this;
331 return node;
332}

◆ SetValue()

void TiXmlNode::SetValue ( const char *  _value)
inline

Changes the value of the node. Defined as:

Document:   filename of the xml file
Element:    name of the element
Comment:    the comment text
Unknown:    the tag contents
Text:       the text string
508{ value = _value;}

◆ ToComment() [1/2]

virtual TiXmlComment * TiXmlNode::ToComment ( )
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlComment.

◆ ToComment() [2/2]

virtual const TiXmlComment * TiXmlNode::ToComment ( ) const
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlComment.

◆ ToDeclaration() [1/2]

virtual TiXmlDeclaration * TiXmlNode::ToDeclaration ( )
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlDeclaration.

◆ ToDeclaration() [2/2]

virtual const TiXmlDeclaration * TiXmlNode::ToDeclaration ( ) const
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlDeclaration.

◆ ToDocument() [1/2]

virtual TiXmlDocument * TiXmlNode::ToDocument ( )
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlDocument.

◆ ToDocument() [2/2]

virtual const TiXmlDocument * TiXmlNode::ToDocument ( ) const
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlDocument.

◆ ToElement() [1/2]

virtual TiXmlElement * TiXmlNode::ToElement ( )
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlElement.

◆ ToElement() [2/2]

virtual const TiXmlElement * TiXmlNode::ToElement ( ) const
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlElement.

◆ ToText() [1/2]

virtual TiXmlText * TiXmlNode::ToText ( )
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlText.

◆ ToText() [2/2]

virtual const TiXmlText * TiXmlNode::ToText ( ) const
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlText.

◆ ToUnknown() [1/2]

virtual TiXmlUnknown * TiXmlNode::ToUnknown ( )
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlUnknown.

◆ ToUnknown() [2/2]

virtual const TiXmlUnknown * TiXmlNode::ToUnknown ( ) const
inlinevirtual

Cast to a more defined type. Will return null if not of the requested type.

Reimplemented in TiXmlUnknown.

◆ Type()

int TiXmlNode::Type ( ) const
inline

Query the type (as an enumerated value, above) of this node. The possible types are: TINYXML_DOCUMENT, TINYXML_ELEMENT, TINYXML_COMMENT, TINYXML_UNKNOWN, TINYXML_TEXT, and TINYXML_DECLARATION.

684{ return type; }

◆ Value()

const char * TiXmlNode::Value ( ) const
inline

The meaning of 'value' changes for the specific type of TiXmlNode.

Document:   filename of the xml file
Element:    name of the element
Comment:    the comment text
Unknown:    the tag contents
Text:       the text string

The subclasses will wrap this function.

487{ return value.c_str (); }

◆ ValueTStr()

const TIXML_STRING & TiXmlNode::ValueTStr ( ) const
inline
497{ return value; }

Friends And Related Function Documentation

◆ TiXmlDocument

friend class TiXmlDocument
friend

◆ TiXmlElement

friend class TiXmlElement
friend

Member Data Documentation

◆ firstChild

TiXmlNode* TiXmlNode::firstChild
protected

◆ lastChild

TiXmlNode* TiXmlNode::lastChild
protected

◆ next

TiXmlNode* TiXmlNode::next
protected

◆ parent

TiXmlNode* TiXmlNode::parent
protected

◆ prev

TiXmlNode* TiXmlNode::prev
protected

◆ type

NodeType TiXmlNode::type
protected

◆ value

TIXML_STRING TiXmlNode::value
protected

The documentation for this class was generated from the following files: