added missing node types

This commit is contained in:
Lee Thomason 2012-02-11 16:33:40 -08:00
parent 751da529d9
commit 50f97b2d06
2 changed files with 157 additions and 54 deletions

View File

@ -210,24 +210,45 @@ char* XMLDocument::Identify( char* p, XMLNode** node )
static const int cdataHeaderLen = 9; static const int cdataHeaderLen = 9;
static const int elementHeaderLen = 1; static const int elementHeaderLen = 1;
if ( XMLUtil::StringEqual( p, commentHeader, commentHeaderLen ) ) { TIXMLASSERT( sizeof( XMLComment ) == sizeof( XMLUnknown ) ); // use same memory pool
TIXMLASSERT( sizeof( XMLComment ) == sizeof( XMLDeclaration ) ); // use same memory pool
if ( XMLUtil::StringEqual( p, xmlHeader, xmlHeaderLen ) ) {
returnNode = new (commentPool.Alloc()) XMLDeclaration( this );
returnNode->memPool = &commentPool;
p += xmlHeaderLen;
}
else if ( XMLUtil::StringEqual( p, commentHeader, commentHeaderLen ) ) {
returnNode = new (commentPool.Alloc()) XMLComment( this ); returnNode = new (commentPool.Alloc()) XMLComment( this );
returnNode->memPool = &commentPool; returnNode->memPool = &commentPool;
p += commentHeaderLen; p += commentHeaderLen;
} }
else if ( XMLUtil::StringEqual( p, cdataHeader, cdataHeaderLen ) ) {
XMLText* text = new (textPool.Alloc()) XMLText( this );
returnNode = text;
returnNode->memPool = &textPool;
p += cdataHeaderLen;
text->SetCData( true );
}
else if ( XMLUtil::StringEqual( p, dtdHeader, dtdHeaderLen ) ) {
returnNode = new (commentPool.Alloc()) XMLUnknown( this );
returnNode->memPool = &commentPool;
p += dtdHeaderLen;
}
else if ( XMLUtil::StringEqual( p, elementHeader, elementHeaderLen ) ) { else if ( XMLUtil::StringEqual( p, elementHeader, elementHeaderLen ) ) {
returnNode = new (elementPool.Alloc()) XMLElement( this ); returnNode = new (elementPool.Alloc()) XMLElement( this );
returnNode->memPool = &elementPool; returnNode->memPool = &elementPool;
p += elementHeaderLen; p += elementHeaderLen;
} }
// fixme: better text detection
else if ( (*p != '<') && XMLUtil::IsAlphaNum( *p ) ) { else if ( (*p != '<') && XMLUtil::IsAlphaNum( *p ) ) {
returnNode = new (textPool.Alloc()) XMLText( this ); returnNode = new (textPool.Alloc()) XMLText( this );
returnNode->memPool = &textPool; returnNode->memPool = &textPool;
p = start; // Back it up, all the text counts. p = start; // Back it up, all the text counts.
} }
else { else {
TIXMLASSERT( 0 ); this->SetError( ERROR_IDENTIFYING_TAG, p, 0 );
p = 0;
returnNode = 0;
} }
*node = returnNode; *node = returnNode;
@ -393,24 +414,21 @@ char* XMLNode::ParseDeep( char* p )
// --------- XMLText ---------- // // --------- XMLText ---------- //
char* XMLText::ParseDeep( char* p ) char* XMLText::ParseDeep( char* p )
{ {
p = value.ParseText( p, "<", StrPair::TEXT_ELEMENT ); if ( this->CData() ) {
// consumes the end tag. p = value.ParseText( p, "]]>", StrPair::NEEDS_NEWLINE_NORMALIZATION );
if ( p && *p ) { return p;
return p-1; }
else {
p = value.ParseText( p, "<", StrPair::TEXT_ELEMENT );
// consumes the end tag.
if ( p && *p ) {
return p-1;
}
} }
return 0; return 0;
} }
/*
void XMLText::Print( XMLStreamer* streamer )
{
const char* v = value.GetStr();
streamer->PushText( v );
}
*/
bool XMLText::Accept( XMLVisitor* visitor ) const bool XMLText::Accept( XMLVisitor* visitor ) const
{ {
return visitor->Visit( *this ); return visitor->Visit( *this );
@ -430,16 +448,6 @@ XMLComment::~XMLComment()
} }
/*
void XMLComment::Print( XMLStreamer* streamer )
{
// XMLNode::Print( fp, depth );
// fprintf( fp, "<!--%s-->\n", value.GetStr() );
streamer->PushComment( value.GetStr() );
}
*/
char* XMLComment::ParseDeep( char* p ) char* XMLComment::ParseDeep( char* p )
{ {
// Comment parses as text. // Comment parses as text.
@ -453,6 +461,55 @@ bool XMLComment::Accept( XMLVisitor* visitor ) const
} }
// --------- XMLDeclaration ---------- //
XMLDeclaration::XMLDeclaration( XMLDocument* doc ) : XMLNode( doc )
{
}
XMLDeclaration::~XMLDeclaration()
{
//printf( "~XMLDeclaration\n" );
}
char* XMLDeclaration::ParseDeep( char* p )
{
// Declaration parses as text.
return value.ParseText( p, ">", StrPair::NEEDS_NEWLINE_NORMALIZATION );
}
bool XMLDeclaration::Accept( XMLVisitor* visitor ) const
{
return visitor->Visit( *this );
}
// --------- XMLUnknown ---------- //
XMLUnknown::XMLUnknown( XMLDocument* doc ) : XMLNode( doc )
{
}
XMLUnknown::~XMLUnknown()
{
}
char* XMLUnknown::ParseDeep( char* p )
{
// Unknown parses as text.
return value.ParseText( p, ">", StrPair::NEEDS_NEWLINE_NORMALIZATION );
}
bool XMLUnknown::Accept( XMLVisitor* visitor ) const
{
return visitor->Visit( *this );
}
// --------- XMLAttribute ---------- // // --------- XMLAttribute ---------- //
char* XMLAttribute::ParseDeep( char* p ) char* XMLAttribute::ParseDeep( char* p )
{ {
@ -862,14 +919,18 @@ void XMLStreamer::SealElement()
} }
void XMLStreamer::PushText( const char* text ) void XMLStreamer::PushText( const char* text, bool cdata )
{ {
textDepth = depth-1; textDepth = depth-1;
if ( elementJustOpened ) { if ( elementJustOpened ) {
SealElement(); SealElement();
} }
if ( cdata )
fprintf( fp, "<![CDATA[" );
PrintString( text ); PrintString( text );
if ( cdata )
fprintf( fp, "]]>" );
} }

View File

@ -1,4 +1,4 @@
#ifndef TINYXML2_INCLUDED #ifndef TINYXML_INCLUDED
#define TINYXML2_INCLUDED #define TINYXML2_INCLUDED
/* /*
@ -50,6 +50,8 @@ class XMLAttribute;
class XMLComment; class XMLComment;
class XMLNode; class XMLNode;
class XMLText; class XMLText;
class XMLDeclaration;
class XMLUnknown;
class XMLStreamer; class XMLStreamer;
@ -267,13 +269,13 @@ public:
virtual bool VisitExit( const XMLElement& /*element*/ ) { return true; } virtual bool VisitExit( const XMLElement& /*element*/ ) { return true; }
/// Visit a declaration /// Visit a declaration
//virtual bool Visit( const TiXmlDeclaration& /*declaration*/ ) { return true; } virtual bool Visit( const XMLDeclaration& /*declaration*/ ) { return true; }
/// Visit a text node /// Visit a text node
virtual bool Visit( const XMLText& /*text*/ ) { return true; } virtual bool Visit( const XMLText& /*text*/ ) { return true; }
/// Visit a comment node /// Visit a comment node
virtual bool Visit( const XMLComment& /*comment*/ ) { return true; } virtual bool Visit( const XMLComment& /*comment*/ ) { return true; }
/// Visit an unknown node /// Visit an unknown node
//virtual bool Visit( const TiXmlUnknown& /*unknown*/ ) { return true; } virtual bool Visit( const XMLUnknown& /*unknown*/ ) { return true; }
}; };
@ -316,11 +318,15 @@ public:
virtual XMLText* ToText() { return 0; } virtual XMLText* ToText() { return 0; }
virtual XMLComment* ToComment() { return 0; } virtual XMLComment* ToComment() { return 0; }
virtual XMLDocument* ToDocument() { return 0; } virtual XMLDocument* ToDocument() { return 0; }
virtual XMLDeclaration* ToDeclaration() { return 0; }
virtual XMLUnknown* ToUnknown() { return 0; }
virtual const XMLElement* ToElement() const { return 0; } virtual const XMLElement* ToElement() const { return 0; }
virtual const XMLText* ToText() const { return 0; } virtual const XMLText* ToText() const { return 0; }
virtual const XMLComment* ToComment() const { return 0; } virtual const XMLComment* ToComment() const { return 0; }
virtual const XMLDocument* ToDocument() const { return 0; } virtual const XMLDocument* ToDocument() const { return 0; }
virtual const XMLDeclaration* ToDeclaration() const { return 0; }
virtual const XMLUnknown* ToUnknown() const { return 0; }
const char* Value() const { return value.GetStr(); } const char* Value() const { return value.GetStr(); }
void SetValue( const char* val ) { value.SetInternedStr( val ); } void SetValue( const char* val ) { value.SetInternedStr( val ); }
@ -395,25 +401,26 @@ class XMLText : public XMLNode
friend class XMLBase; friend class XMLBase;
friend class XMLDocument; friend class XMLDocument;
public: public:
//virtual void Print( XMLStreamer* streamer );
virtual bool Accept( XMLVisitor* visitor ) const; virtual bool Accept( XMLVisitor* visitor ) const;
virtual XMLText* ToText() { return this; } virtual XMLText* ToText() { return this; }
virtual const XMLText* ToText() const { return this; } virtual const XMLText* ToText() const { return this; }
void SetCData( bool value ) { isCData = true; }
bool CData() const { return isCData; }
char* ParseDeep( char* ); char* ParseDeep( char* );
protected: protected:
XMLText( XMLDocument* doc ) : XMLNode( doc ) {} XMLText( XMLDocument* doc ) : XMLNode( doc ), isCData( false ) {}
virtual ~XMLText() {} virtual ~XMLText() {}
private: private:
bool isCData;
}; };
class XMLComment : public XMLNode class XMLComment : public XMLNode
{ {
friend class XMLBase;
friend class XMLDocument; friend class XMLDocument;
public: public:
virtual XMLComment* ToComment() { return this; } virtual XMLComment* ToComment() { return this; }
@ -431,6 +438,40 @@ private:
}; };
class XMLDeclaration : public XMLNode
{
friend class XMLDocument;
public:
virtual XMLDeclaration* ToDeclaration() { return this; }
virtual const XMLDeclaration* ToDeclaration() const { return this; }
virtual bool Accept( XMLVisitor* visitor ) const;
char* ParseDeep( char* );
protected:
XMLDeclaration( XMLDocument* doc );
virtual ~XMLDeclaration();
};
class XMLUnknown : public XMLNode
{
friend class XMLDocument;
public:
virtual XMLUnknown* ToUnknown() { return this; }
virtual const XMLUnknown* ToUnknown() const { return this; }
virtual bool Accept( XMLVisitor* visitor ) const;
char* ParseDeep( char* );
protected:
XMLUnknown( XMLDocument* doc );
virtual ~XMLUnknown();
};
class XMLAttribute class XMLAttribute
{ {
friend class XMLElement; friend class XMLElement;
@ -525,7 +566,8 @@ public:
NO_ERROR = 0, NO_ERROR = 0,
ERROR_ELEMENT_MISMATCH, ERROR_ELEMENT_MISMATCH,
ERROR_PARSING_ELEMENT, ERROR_PARSING_ELEMENT,
ERROR_PARSING_ATTRIBUTE ERROR_PARSING_ATTRIBUTE,
ERROR_IDENTIFYING_TAG
}; };
void SetError( int error, const char* str1, const char* str2 ); void SetError( int error, const char* str1, const char* str2 );
@ -563,7 +605,7 @@ public:
void PushAttribute( const char* name, const char* value ); void PushAttribute( const char* name, const char* value );
void CloseElement(); void CloseElement();
void PushText( const char* text ); void PushText( const char* text, bool cdata=false );
void PushComment( const char* comment ); void PushComment( const char* comment );
virtual bool VisitEnter( const XMLDocument& /*doc*/ ) { return true; } virtual bool VisitEnter( const XMLDocument& /*doc*/ ) { return true; }