CMS 3D CMS Logo

Public Member Functions | Protected Member Functions

TiXmlUnknown Class Reference

#include <tinyxml.h>

Inheritance diagram for TiXmlUnknown:
TiXmlNode TiXmlBase

List of all members.

Public Member Functions

virtual bool Accept (TiXmlVisitor *content) const
virtual TiXmlNodeClone () const
 Creates a copy of this Unknown and returns it.
TiXmlUnknownoperator= (const TiXmlUnknown &copy)
virtual const char * Parse (const char *p, TiXmlParsingData *data, TiXmlEncoding encoding)
virtual void Print (FILE *cfile, int depth) const
 TiXmlUnknown ()
 TiXmlUnknown (const TiXmlUnknown &copy)
virtual const TiXmlUnknownToUnknown () const
 Cast to a more defined type. Will return null not of the requested type.
virtual TiXmlUnknownToUnknown ()
 Cast to a more defined type. Will return null not of the requested type.
virtual ~TiXmlUnknown ()

Protected Member Functions

void CopyTo (TiXmlUnknown *target) const
virtual void StreamIn (std::istream *in, TIXML_STRING *tag)

Detailed Description

Any tag that tinyXml doesn't recognize is saved as an unknown. It is a tag of text, but should not be modified. It will be written back to the XML, unchanged, when the file is saved.

DTD tags get thrown into TiXmlUnknowns.

Definition at line 1349 of file tinyxml.h.


Constructor & Destructor Documentation

TiXmlUnknown::TiXmlUnknown ( ) [inline]

Definition at line 1352 of file tinyxml.h.

Referenced by Clone().

virtual TiXmlUnknown::~TiXmlUnknown ( ) [inline, virtual]

Definition at line 1353 of file tinyxml.h.

{}
TiXmlUnknown::TiXmlUnknown ( const TiXmlUnknown copy) [inline]

Definition at line 1355 of file tinyxml.h.

References CopyTo().

: TiXmlNode( TiXmlNode::UNKNOWN )               { copy.CopyTo( this ); }

Member Function Documentation

bool TiXmlUnknown::Accept ( TiXmlVisitor content) const [virtual]

Walk the XML tree visiting this node and all of its children.

Implements TiXmlNode.

Definition at line 1502 of file tinyxml.cc.

References TiXmlVisitor::Visit().

{
        return visitor->Visit( *this );
}
TiXmlNode * TiXmlUnknown::Clone ( ) const [virtual]

Creates a copy of this Unknown and returns it.

Implements TiXmlNode.

Definition at line 1508 of file tinyxml.cc.

References clone(), CopyTo(), and TiXmlUnknown().

{
        TiXmlUnknown* clone = new TiXmlUnknown();

        if ( !clone )
                return 0;

        CopyTo( clone );
        return clone;
}
void TiXmlUnknown::CopyTo ( TiXmlUnknown target) const [protected]

Definition at line 1496 of file tinyxml.cc.

Referenced by Clone(), operator=(), and TiXmlUnknown().

{
        TiXmlNode::CopyTo( target );
}
TiXmlUnknown& TiXmlUnknown::operator= ( const TiXmlUnknown copy) [inline]

Definition at line 1356 of file tinyxml.h.

References CopyTo().

{ copy.CopyTo( this ); return *this;}
const char * TiXmlUnknown::Parse ( const char *  p,
TiXmlParsingData data,
TiXmlEncoding  encoding 
) [virtual]

Implements TiXmlBase.

Definition at line 1284 of file tinyxmlparser.cc.

References TiXmlParsingData::Cursor(), TiXmlNode::GetDocument(), TiXmlBase::location, AlCaHLTBitMon_ParallelJobs::p, TiXmlDocument::SetError(), TiXmlBase::SkipWhiteSpace(), TiXmlParsingData::Stamp(), TiXmlBase::TIXML_ERROR_PARSING_UNKNOWN, and TiXmlNode::value.

{
        TiXmlDocument* document = GetDocument();
        p = SkipWhiteSpace( p, encoding );

        if ( data )
        {
                data->Stamp( p, encoding );
                location = data->Cursor();
        }
        if ( !p || !*p || *p != '<' )
        {
                if ( document ) document->SetError( TIXML_ERROR_PARSING_UNKNOWN, p, data, encoding );
                return 0;
        }
        ++p;
    value = "";

        while ( p && *p && *p != '>' )
        {
                value += *p;
                ++p;
        }

        if ( !p )
        {
                if ( document ) document->SetError( TIXML_ERROR_PARSING_UNKNOWN, 0, 0, encoding );
        }
        if ( *p == '>' )
                return p+1;
        return p;
}
void TiXmlUnknown::Print ( FILE *  cfile,
int  depth 
) const [virtual]

All TinyXml classes can print themselves to a filestream or the string class (TiXmlString in non-STL mode, std::string in STL mode.) Either or both cfile and str can be null.

This is a formatted print, and will insert tabs and newlines.

(For an unformatted stream, use the << operator.)

Implements TiXmlBase.

Definition at line 1488 of file tinyxml.cc.

References TiXmlNode::value.

{
        for ( int i=0; i<depth; i++ )
                fprintf( cfile, "    " );
        fprintf( cfile, "<%s>", value.c_str() );
}
virtual void TiXmlUnknown::StreamIn ( std::istream *  in,
TIXML_STRING *  tag 
) [protected, virtual]

Implements TiXmlNode.

virtual const TiXmlUnknown* TiXmlUnknown::ToUnknown ( ) const [inline, virtual]

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

Reimplemented from TiXmlNode.

Definition at line 1365 of file tinyxml.h.

virtual TiXmlUnknown* TiXmlUnknown::ToUnknown ( ) [inline, virtual]

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

Reimplemented from TiXmlNode.

Definition at line 1366 of file tinyxml.h.