NumeRe v1.1.4
NumeRe: Framework für Numerische Rechnungen
tinyxml2::XMLPrinter Class Reference

#include <tinyxml2.h>

Inheritance diagram for tinyxml2::XMLPrinter:
Collaboration diagram for tinyxml2::XMLPrinter:

Public Member Functions

 XMLPrinter (FILE *file=0, bool compact=false, int depth=0)
 
virtual ~XMLPrinter ()
 
void PushHeader (bool writeBOM, bool writeDeclaration)
 
void OpenElement (const char *name, bool compactMode=false)
 
void PushAttribute (const char *name, const char *value)
 If streaming, add an attribute to an open element. More...
 
void PushAttribute (const char *name, int value)
 
void PushAttribute (const char *name, unsigned value)
 
void PushAttribute (const char *name, int64_t value)
 
void PushAttribute (const char *name, uint64_t value)
 
void PushAttribute (const char *name, bool value)
 
void PushAttribute (const char *name, double value)
 
virtual void CloseElement (bool compactMode=false)
 If streaming, close the Element. More...
 
void PushText (const char *text, bool cdata=false)
 Add a text node. More...
 
void PushText (int value)
 Add a text node from an integer. More...
 
void PushText (unsigned value)
 Add a text node from an unsigned. More...
 
void PushText (int64_t value)
 Add a text node from a signed 64bit integer. More...
 
void PushText (uint64_t value)
 Add a text node from an unsigned 64bit integer. More...
 
void PushText (bool value)
 Add a text node from a bool. More...
 
void PushText (float value)
 Add a text node from a float. More...
 
void PushText (double value)
 Add a text node from a double. More...
 
void PushComment (const char *comment)
 Add a comment. More...
 
void PushDeclaration (const char *value)
 
void PushUnknown (const char *value)
 
virtual bool VisitEnter (const XMLDocument &)
 Visit a document. More...
 
virtual bool VisitExit (const XMLDocument &)
 Visit a document. More...
 
virtual bool VisitEnter (const XMLElement &element, const XMLAttribute *attribute)
 Visit an element. More...
 
virtual bool VisitExit (const XMLElement &element)
 Visit an element. More...
 
virtual bool Visit (const XMLText &text)
 Visit a text node. More...
 
virtual bool Visit (const XMLComment &comment)
 Visit a comment node. More...
 
virtual bool Visit (const XMLDeclaration &declaration)
 Visit a declaration. More...
 
virtual bool Visit (const XMLUnknown &unknown)
 Visit an unknown node. More...
 
const char * CStr () const
 
int CStrSize () const
 
void ClearBuffer (bool resetToFirstElement=true)
 
- Public Member Functions inherited from tinyxml2::XMLVisitor
virtual ~XMLVisitor ()
 
virtual bool VisitEnter (const XMLDocument &)
 Visit a document. More...
 
virtual bool VisitExit (const XMLDocument &)
 Visit a document. More...
 
virtual bool VisitEnter (const XMLElement &, const XMLAttribute *)
 Visit an element. More...
 
virtual bool VisitExit (const XMLElement &)
 Visit an element. More...
 
virtual bool Visit (const XMLDeclaration &)
 Visit a declaration. More...
 
virtual bool Visit (const XMLText &)
 Visit a text node. More...
 
virtual bool Visit (const XMLComment &)
 Visit a comment node. More...
 
virtual bool Visit (const XMLUnknown &)
 Visit an unknown node. More...
 

Protected Member Functions

virtual bool CompactMode (const XMLElement &)
 
virtual void PrintSpace (int depth)
 
virtual void Print (const char *format,...)
 
virtual void Write (const char *data, size_t size)
 
virtual void Putc (char ch)
 
void Write (const char *data)
 
void SealElementIfJustOpened ()
 

Protected Attributes

bool _elementJustOpened
 
DynArray< const char *, 10 > _stack
 

Private Types

enum  { ENTITY_RANGE = 64 , BUF_SIZE = 200 }
 

Private Member Functions

void PrepareForNewNode (bool compactMode)
 
void PrintString (const char *, bool restrictedEntitySet)
 
 XMLPrinter (const XMLPrinter &)
 
XMLPrinteroperator= (const XMLPrinter &)
 

Private Attributes

bool _firstElement
 
FILE * _fp
 
int _depth
 
int _textDepth
 
bool _processEntities
 
bool _compactMode
 
bool _entityFlag [ENTITY_RANGE]
 
bool _restrictedEntityFlag [ENTITY_RANGE]
 
DynArray< char, 20 > _buffer
 

Detailed Description

Printing functionality. The XMLPrinter gives you more options than the XMLDocument::Print() method.

It can:

  1. Print to memory.
  2. Print to a file you provide.
  3. Print XML without a XMLDocument.

Print to Memory

XMLPrinter printer;
doc.Print( &printer );
SomeFunction( printer.CStr() );

Print to a File

You provide the file pointer.

XMLPrinter printer( fp );
doc.Print( &printer );

Print without a XMLDocument

When loading, an XML parser is very useful. However, sometimes when saving, it just gets in the way. The code is often set up for streaming, and constructing the DOM is just overhead.

The Printer supports the streaming case. The following code prints out a trivially simple XML file without ever creating an XML document.

XMLPrinter printer( fp );
printer.OpenElement( "foo" );
printer.PushAttribute( "foo", "bar" );
printer.CloseElement();

Definition at line 2237 of file tinyxml2.h.

Member Enumeration Documentation

◆ anonymous enum

anonymous enum
private
Enumerator
ENTITY_RANGE 
BUF_SIZE 

Definition at line 2359 of file tinyxml2.h.

Constructor & Destructor Documentation

◆ XMLPrinter() [1/2]

tinyxml2::XMLPrinter::XMLPrinter ( FILE *  file = 0,
bool  compact = false,
int  depth = 0 
)

Construct the printer. If the FILE* is specified, this will print to the FILE. Else it will print to memory, and the result is available in CStr(). If 'compact' is set to true, then output is created with only required whitespace and newlines.

Definition at line 2547 of file tinyxml2.cpp.

References _buffer, _entityFlag, _restrictedEntityFlag, tinyxml2::entities, ENTITY_RANGE, tinyxml2::NUM_ENTITIES, tinyxml2::DynArray< T, INITIAL_SIZE >::Push(), TIXMLASSERT, and tinyxml2::Entity::value.

Here is the call graph for this function:

◆ ~XMLPrinter()

virtual tinyxml2::XMLPrinter::~XMLPrinter ( )
inlinevirtual

Definition at line 2247 of file tinyxml2.h.

◆ XMLPrinter() [2/2]

tinyxml2::XMLPrinter::XMLPrinter ( const XMLPrinter )
private

Member Function Documentation

◆ ClearBuffer()

void tinyxml2::XMLPrinter::ClearBuffer ( bool  resetToFirstElement = true)
inline

If in print to memory mode, reset the buffer to the beginning.

Definition at line 2321 of file tinyxml2.h.

◆ CloseElement()

void tinyxml2::XMLPrinter::CloseElement ( bool  compactMode = false)
virtual

If streaming, close the Element.

Definition at line 2787 of file tinyxml2.cpp.

References _depth, _elementJustOpened, _stack, _textDepth, name, tinyxml2::DynArray< T, INITIAL_SIZE >::Pop(), PrintSpace(), Putc(), and Write().

Referenced by VisitExit().

Here is the call graph for this function:

◆ CompactMode()

virtual bool tinyxml2::XMLPrinter::CompactMode ( const XMLElement )
inlineprotectedvirtual

Definition at line 2328 of file tinyxml2.h.

Referenced by VisitEnter(), and VisitExit().

◆ CStr()

const char * tinyxml2::XMLPrinter::CStr ( ) const
inline

If in print to memory mode, return a pointer to the XML file in memory.

Definition at line 2306 of file tinyxml2.h.

◆ CStrSize()

int tinyxml2::XMLPrinter::CStrSize ( ) const
inline

If in print to memory mode, return the size of the XML file in memory. (Note the size returned includes the terminating null.)

Definition at line 2314 of file tinyxml2.h.

◆ OpenElement()

void tinyxml2::XMLPrinter::OpenElement ( const char *  name,
bool  compactMode = false 
)

If streaming, start writing an element. The element must be closed with CloseElement()

Definition at line 2715 of file tinyxml2.cpp.

References _depth, _elementJustOpened, _stack, name, PrepareForNewNode(), tinyxml2::DynArray< T, INITIAL_SIZE >::Push(), and Write().

Referenced by VisitEnter().

Here is the call graph for this function:

◆ operator=()

XMLPrinter & tinyxml2::XMLPrinter::operator= ( const XMLPrinter )
private

◆ PrepareForNewNode()

void tinyxml2::XMLPrinter::PrepareForNewNode ( bool  compactMode)
private

Prepares to write a new node. This includes sealing an element that was just opened, and writing any whitespace necessary if not in compact mode.

Definition at line 2697 of file tinyxml2.cpp.

References _depth, _firstElement, _textDepth, PrintSpace(), Putc(), and SealElementIfJustOpened().

Referenced by OpenElement(), PushComment(), PushDeclaration(), and PushUnknown().

Here is the call graph for this function:

◆ Print()

void tinyxml2::XMLPrinter::Print ( const char *  format,
  ... 
)
protectedvirtual

Definition at line 2575 of file tinyxml2.cpp.

References _buffer, _fp, date::format(), tinyxml2::DynArray< T, INITIAL_SIZE >::PushArr(), tinyxml2::DynArray< T, INITIAL_SIZE >::Size(), TIXML_VSCPRINTF(), TIXML_VSNPRINTF, and TIXMLASSERT.

Here is the call graph for this function:

◆ PrintSpace()

void tinyxml2::XMLPrinter::PrintSpace ( int  depth)
protectedvirtual

Prints out the space before an element. You may override to change the space and tabs used. A PrintSpace() override should call Print().

Definition at line 2623 of file tinyxml2.cpp.

References Write().

Referenced by CloseElement(), and PrepareForNewNode().

Here is the call graph for this function:

◆ PrintString()

void tinyxml2::XMLPrinter::PrintString ( const char *  p,
bool  restrictedEntitySet 
)
private

Definition at line 2631 of file tinyxml2.cpp.

References _entityFlag, _processEntities, _restrictedEntityFlag, tinyxml2::entities, ENTITY_RANGE, tinyxml2::NUM_ENTITIES, Putc(), TIXMLASSERT, and Write().

Referenced by PushAttribute(), and PushText().

Here is the call graph for this function:

◆ PushAttribute() [1/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
bool  value 
)

Definition at line 2771 of file tinyxml2.cpp.

References BUF_SIZE, name, PushAttribute(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushAttribute() [2/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
const char *  value 
)

If streaming, add an attribute to an open element.

Definition at line 2728 of file tinyxml2.cpp.

References _elementJustOpened, name, PrintString(), Putc(), TIXMLASSERT, and Write().

Referenced by PushAttribute(), and VisitEnter().

Here is the call graph for this function:

◆ PushAttribute() [3/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
double  value 
)

Definition at line 2779 of file tinyxml2.cpp.

References BUF_SIZE, name, PushAttribute(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushAttribute() [4/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
int  value 
)

Definition at line 2739 of file tinyxml2.cpp.

References BUF_SIZE, name, PushAttribute(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushAttribute() [5/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
int64_t  value 
)

Definition at line 2755 of file tinyxml2.cpp.

References BUF_SIZE, name, PushAttribute(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushAttribute() [6/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
uint64_t  value 
)

Definition at line 2763 of file tinyxml2.cpp.

References BUF_SIZE, name, PushAttribute(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushAttribute() [7/7]

void tinyxml2::XMLPrinter::PushAttribute ( const char *  name,
unsigned  value 
)

Definition at line 2747 of file tinyxml2.cpp.

References BUF_SIZE, name, PushAttribute(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushComment()

void tinyxml2::XMLPrinter::PushComment ( const char *  comment)

Add a comment.

Definition at line 2897 of file tinyxml2.cpp.

References _compactMode, PrepareForNewNode(), and Write().

Referenced by Visit().

Here is the call graph for this function:

◆ PushDeclaration()

void tinyxml2::XMLPrinter::PushDeclaration ( const char *  value)

Definition at line 2907 of file tinyxml2.cpp.

References _compactMode, PrepareForNewNode(), and Write().

Referenced by PushHeader(), and Visit().

Here is the call graph for this function:

◆ PushHeader()

void tinyxml2::XMLPrinter::PushHeader ( bool  writeBOM,
bool  writeDeclaration 
)

If streaming, write the BOM and declaration.

Definition at line 2686 of file tinyxml2.cpp.

References PushDeclaration(), TIXML_UTF_LEAD_0, TIXML_UTF_LEAD_1, TIXML_UTF_LEAD_2, and Write().

Referenced by VisitEnter().

Here is the call graph for this function:

◆ PushText() [1/8]

void tinyxml2::XMLPrinter::PushText ( bool  value)

Add a text node from a bool.

Definition at line 2873 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushText() [2/8]

void tinyxml2::XMLPrinter::PushText ( const char *  text,
bool  cdata = false 
)

Add a text node.

Definition at line 2825 of file tinyxml2.cpp.

References _depth, _textDepth, PrintString(), SealElementIfJustOpened(), and Write().

Referenced by PushText(), and Visit().

Here is the call graph for this function:

◆ PushText() [3/8]

void tinyxml2::XMLPrinter::PushText ( double  value)

Add a text node from a double.

Definition at line 2889 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushText() [4/8]

void tinyxml2::XMLPrinter::PushText ( float  value)

Add a text node from a float.

Definition at line 2881 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushText() [5/8]

void tinyxml2::XMLPrinter::PushText ( int  value)

Add a text node from an integer.

Definition at line 2857 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushText() [6/8]

void tinyxml2::XMLPrinter::PushText ( int64_t  value)

Add a text node from a signed 64bit integer.

Definition at line 2841 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushText() [7/8]

void tinyxml2::XMLPrinter::PushText ( uint64_t  value)

Add a text node from an unsigned 64bit integer.

Definition at line 2849 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushText() [8/8]

void tinyxml2::XMLPrinter::PushText ( unsigned  value)

Add a text node from an unsigned.

Definition at line 2865 of file tinyxml2.cpp.

References BUF_SIZE, PushText(), and tinyxml2::XMLUtil::ToStr().

Here is the call graph for this function:

◆ PushUnknown()

void tinyxml2::XMLPrinter::PushUnknown ( const char *  value)

Definition at line 2917 of file tinyxml2.cpp.

References _compactMode, PrepareForNewNode(), Putc(), and Write().

Referenced by Visit().

Here is the call graph for this function:

◆ Putc()

void tinyxml2::XMLPrinter::Putc ( char  ch)
protectedvirtual

Definition at line 2610 of file tinyxml2.cpp.

References _buffer, _fp, and tinyxml2::DynArray< T, INITIAL_SIZE >::PushArr().

Referenced by CloseElement(), PrepareForNewNode(), PrintString(), PushAttribute(), PushUnknown(), and SealElementIfJustOpened().

Here is the call graph for this function:

◆ SealElementIfJustOpened()

void tinyxml2::XMLPrinter::SealElementIfJustOpened ( )
protected

Definition at line 2815 of file tinyxml2.cpp.

References _elementJustOpened, and Putc().

Referenced by PrepareForNewNode(), and PushText().

Here is the call graph for this function:

◆ Visit() [1/4]

bool tinyxml2::XMLPrinter::Visit ( const XMLComment )
virtual

Visit a comment node.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2967 of file tinyxml2.cpp.

References PushComment(), and tinyxml2::XMLNode::Value().

Here is the call graph for this function:

◆ Visit() [2/4]

bool tinyxml2::XMLPrinter::Visit ( const XMLDeclaration )
virtual

Visit a declaration.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2973 of file tinyxml2.cpp.

References PushDeclaration(), and tinyxml2::XMLNode::Value().

Here is the call graph for this function:

◆ Visit() [3/4]

bool tinyxml2::XMLPrinter::Visit ( const XMLText )
virtual

Visit a text node.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2960 of file tinyxml2.cpp.

References tinyxml2::XMLText::CData(), PushText(), and tinyxml2::XMLNode::Value().

Here is the call graph for this function:

◆ Visit() [4/4]

bool tinyxml2::XMLPrinter::Visit ( const XMLUnknown )
virtual

Visit an unknown node.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2980 of file tinyxml2.cpp.

References PushUnknown(), and tinyxml2::XMLNode::Value().

Here is the call graph for this function:

◆ VisitEnter() [1/2]

bool tinyxml2::XMLPrinter::VisitEnter ( const XMLDocument )
virtual

Visit a document.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2927 of file tinyxml2.cpp.

References _processEntities, tinyxml2::XMLDocument::HasBOM(), tinyxml2::XMLDocument::ProcessEntities(), and PushHeader().

Here is the call graph for this function:

◆ VisitEnter() [2/2]

bool tinyxml2::XMLPrinter::VisitEnter ( const XMLElement ,
const XMLAttribute  
)
virtual

Visit an element.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2937 of file tinyxml2.cpp.

References _compactMode, CompactMode(), tinyxml2::XMLAttribute::Name(), tinyxml2::XMLElement::Name(), tinyxml2::XMLAttribute::Next(), OpenElement(), tinyxml2::XMLNode::Parent(), PushAttribute(), tinyxml2::XMLNode::ToElement(), and tinyxml2::XMLAttribute::Value().

Here is the call graph for this function:

◆ VisitExit() [1/2]

virtual bool tinyxml2::XMLPrinter::VisitExit ( const XMLDocument )
inlinevirtual

Visit a document.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2290 of file tinyxml2.h.

◆ VisitExit() [2/2]

bool tinyxml2::XMLPrinter::VisitExit ( const XMLElement )
virtual

Visit an element.

Reimplemented from tinyxml2::XMLVisitor.

Definition at line 2953 of file tinyxml2.cpp.

References CloseElement(), and CompactMode().

Here is the call graph for this function:

◆ Write() [1/2]

void tinyxml2::XMLPrinter::Write ( const char *  data)
inlineprotected

Definition at line 2338 of file tinyxml2.h.

References Write().

Referenced by Write().

Here is the call graph for this function:

◆ Write() [2/2]

void tinyxml2::XMLPrinter::Write ( const char *  data,
size_t  size 
)
protectedvirtual

Definition at line 2597 of file tinyxml2.cpp.

References _buffer, _fp, and tinyxml2::DynArray< T, INITIAL_SIZE >::PushArr().

Referenced by CloseElement(), OpenElement(), PrintSpace(), PrintString(), PushAttribute(), PushComment(), PushDeclaration(), PushHeader(), PushText(), and PushUnknown().

Here is the call graph for this function:

Member Data Documentation

◆ _buffer

DynArray< char, 20 > tinyxml2::XMLPrinter::_buffer
private

Definition at line 2366 of file tinyxml2.h.

Referenced by Print(), Putc(), Write(), and XMLPrinter().

◆ _compactMode

bool tinyxml2::XMLPrinter::_compactMode
private

Definition at line 2357 of file tinyxml2.h.

Referenced by PushComment(), PushDeclaration(), PushUnknown(), and VisitEnter().

◆ _depth

int tinyxml2::XMLPrinter::_depth
private

Definition at line 2354 of file tinyxml2.h.

Referenced by CloseElement(), OpenElement(), PrepareForNewNode(), and PushText().

◆ _elementJustOpened

bool tinyxml2::XMLPrinter::_elementJustOpened
protected

Definition at line 2341 of file tinyxml2.h.

Referenced by CloseElement(), OpenElement(), PushAttribute(), and SealElementIfJustOpened().

◆ _entityFlag

bool tinyxml2::XMLPrinter::_entityFlag[ENTITY_RANGE]
private

Definition at line 2363 of file tinyxml2.h.

Referenced by PrintString(), and XMLPrinter().

◆ _firstElement

bool tinyxml2::XMLPrinter::_firstElement
private

Definition at line 2352 of file tinyxml2.h.

Referenced by PrepareForNewNode().

◆ _fp

FILE* tinyxml2::XMLPrinter::_fp
private

Definition at line 2353 of file tinyxml2.h.

Referenced by Print(), Putc(), and Write().

◆ _processEntities

bool tinyxml2::XMLPrinter::_processEntities
private

Definition at line 2356 of file tinyxml2.h.

Referenced by PrintString(), and VisitEnter().

◆ _restrictedEntityFlag

bool tinyxml2::XMLPrinter::_restrictedEntityFlag[ENTITY_RANGE]
private

Definition at line 2364 of file tinyxml2.h.

Referenced by PrintString(), and XMLPrinter().

◆ _stack

DynArray< const char*, 10 > tinyxml2::XMLPrinter::_stack
protected

Definition at line 2342 of file tinyxml2.h.

Referenced by CloseElement(), and OpenElement().

◆ _textDepth

int tinyxml2::XMLPrinter::_textDepth
private

Definition at line 2355 of file tinyxml2.h.

Referenced by CloseElement(), PrepareForNewNode(), and PushText().


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