MTK++ Latest version: 0.2.0

Public Member Functions | Private Member Functions | Private Attributes
TiXmlPrinter Class Reference

#include <mtkpp/src/tinyxml/tinyxml.h>

Inheritance diagram for TiXmlPrinter:
Inheritance graph
[legend]
Collaboration diagram for TiXmlPrinter:
Collaboration graph
[legend]

List of all members.

Public Member Functions

 TiXmlPrinter ()
virtual bool VisitEnter (const TiXmlDocument &doc)
 Visit a document.
virtual bool VisitExit (const TiXmlDocument &doc)
 Visit a document.
virtual bool VisitEnter (const TiXmlElement &element, const TiXmlAttribute *firstAttribute)
 Visit an element.
virtual bool VisitExit (const TiXmlElement &element)
 Visit an element.
virtual bool Visit (const TiXmlDeclaration &declaration)
 Visit a declaration.
virtual bool Visit (const TiXmlText &text)
 Visit a text node.
virtual bool Visit (const TiXmlComment &comment)
 Visit a comment node.
virtual bool Visit (const TiXmlUnknown &unknown)
 Visit an unknow node.
void SetIndent (const char *_indent)
const char * Indent ()
 Query the indention string.
void SetLineBreak (const char *_lineBreak)
const char * LineBreak ()
 Query the current line breaking string.
void SetStreamPrinting ()
const char * CStr ()
 Return the result.
size_t Size ()
 Return the length of the result string.

Private Member Functions

void DoIndent ()
void DoLineBreak ()

Private Attributes

int depth
bool simpleTextPrint
TIXML_STRING buffer
TIXML_STRING indent
TIXML_STRING lineBreak

Detailed Description

Print to memory functionality. The TiXmlPrinter is useful when you need to:

  1. Print to memory (especially in non-STL mode)
  2. Control formatting (line endings, etc.)

When constructed, the TiXmlPrinter is in its default "pretty printing" mode. Before calling Accept() you can call methods to control the printing of the XML document. After TiXmlNode::Accept() is called, the printed document can be accessed via the CStr(), Str(), and Size() methods.

TiXmlPrinter uses the Visitor API.

	TiXmlPrinter printer;
	printer.SetIndent( "\t" );

	doc.Accept( &printer );
	fprintf( stdout, "%s", printer.CStr() );
	

Constructor & Destructor Documentation

TiXmlPrinter::TiXmlPrinter ( ) [inline]

Member Function Documentation

bool TiXmlPrinter::VisitEnter ( const TiXmlDocument ) [virtual]

Visit a document.

Reimplemented from TiXmlVisitor.

bool TiXmlPrinter::VisitExit ( const TiXmlDocument ) [virtual]

Visit a document.

Reimplemented from TiXmlVisitor.

bool TiXmlPrinter::VisitEnter ( const TiXmlElement ,
const TiXmlAttribute  
) [virtual]
bool TiXmlPrinter::VisitExit ( const TiXmlElement ) [virtual]

Visit an element.

Reimplemented from TiXmlVisitor.

References buffer, depth, DoIndent(), DoLineBreak(), TiXmlNode::FirstChild(), simpleTextPrint, and TiXmlNode::Value().

bool TiXmlPrinter::Visit ( const TiXmlDeclaration ) [virtual]

Visit a declaration.

Reimplemented from TiXmlVisitor.

References buffer, DoIndent(), DoLineBreak(), and TiXmlDeclaration::Print().

bool TiXmlPrinter::Visit ( const TiXmlText ) [virtual]
bool TiXmlPrinter::Visit ( const TiXmlComment ) [virtual]

Visit a comment node.

Reimplemented from TiXmlVisitor.

References buffer, DoIndent(), DoLineBreak(), and TiXmlNode::Value().

bool TiXmlPrinter::Visit ( const TiXmlUnknown ) [virtual]

Visit an unknow node.

Reimplemented from TiXmlVisitor.

References buffer, DoIndent(), DoLineBreak(), and TiXmlNode::Value().

void TiXmlPrinter::SetIndent ( const char *  _indent) [inline]

Set the indent characters for printing. By default 4 spaces but tab () is also useful, or null/empty string for no indentation.

References indent.

const char* TiXmlPrinter::Indent ( ) [inline]

Query the indention string.

References indent.

void TiXmlPrinter::SetLineBreak ( const char *  _lineBreak) [inline]

Set the line breaking string. By default set to newline (
). Some operating systems prefer other characters, or can be set to the null/empty string for no indenation.

References lineBreak.

const char* TiXmlPrinter::LineBreak ( ) [inline]

Query the current line breaking string.

References lineBreak.

void TiXmlPrinter::SetStreamPrinting ( ) [inline]

Switch over to "stream printing" which is the most dense formatting without linebreaks. Common when the XML is needed for network transmission.

References indent, and lineBreak.

const char* TiXmlPrinter::CStr ( ) [inline]

Return the result.

References buffer.

size_t TiXmlPrinter::Size ( ) [inline]

Return the length of the result string.

References buffer.

void TiXmlPrinter::DoIndent ( ) [inline, private]

References buffer, depth, and indent.

Referenced by Visit(), VisitEnter(), and VisitExit().

void TiXmlPrinter::DoLineBreak ( ) [inline, private]

References buffer, and lineBreak.

Referenced by Visit(), VisitEnter(), and VisitExit().


Member Data Documentation

int TiXmlPrinter::depth [private]

Referenced by DoIndent(), VisitEnter(), and VisitExit().

Referenced by Visit(), VisitEnter(), and VisitExit().

TIXML_STRING TiXmlPrinter::buffer [private]
TIXML_STRING TiXmlPrinter::indent [private]
TIXML_STRING TiXmlPrinter::lineBreak [private]

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

Generated on Fri Dec 23 2011 09:28:55 for MTK++ by Doxygen 1.7.5.1