Add compact mode to XMLPrinter, for printing without '\n' and space.

let output file smaller.
usage:
//------------------------------------------------
XMLPrinter printer;
printer->SetCompactMode( true ); //enable compact mode
doc->Print( &printer );
SomeFunction( printer.CStr() );
//------------------------------------------------
or
//------------------------------------------------
//enable at construction
XMLPrinter printer( file, true );         // to file
//XMLPrinter printer( NULL, true ); // to men
doc->Print( &printer );
SomeFunction( printer.CStr() );
//------------------------------------------------

The '\n' and space in Text or Attribute will be kept.
This commit is contained in:
sniperbat
2012-05-28 17:22:07 +08:00
parent 48ea0bcf80
commit 2590088631
2 changed files with 19 additions and 9 deletions

View File

@@ -1501,13 +1501,14 @@ void XMLDocument::PrintError() const
}
XMLPrinter::XMLPrinter( FILE* file ) :
XMLPrinter::XMLPrinter( FILE* file, bool compact ) :
elementJustOpened( false ),
firstElement( true ),
fp( file ),
depth( 0 ),
textDepth( -1 ),
processEntities( true )
processEntities( true ),
compactMode( compact )
{
for( int i=0; i<ENTITY_RANGE; ++i ) {
entityFlag[i] = false;
@@ -1627,7 +1628,7 @@ void XMLPrinter::OpenElement( const char* name )
}
stack.Push( name );
if ( textDepth < 0 && !firstElement ) {
if ( textDepth < 0 && !firstElement && !compactMode ) {
Print( "\n" );
PrintSpace( depth );
}
@@ -1689,7 +1690,7 @@ void XMLPrinter::CloseElement()
Print( "/>" );
}
else {
if ( textDepth < 0 ) {
if ( textDepth < 0 && !compactMode) {
Print( "\n" );
PrintSpace( depth );
}
@@ -1698,7 +1699,7 @@ void XMLPrinter::CloseElement()
if ( textDepth == depth )
textDepth = -1;
if ( depth == 0 )
if ( depth == 0 && !compactMode)
Print( "\n" );
elementJustOpened = false;
}
@@ -1734,7 +1735,7 @@ void XMLPrinter::PushComment( const char* comment )
if ( elementJustOpened ) {
SealElement();
}
if ( textDepth < 0 && !firstElement ) {
if ( textDepth < 0 && !firstElement && !compactMode) {
Print( "\n" );
PrintSpace( depth );
}
@@ -1748,7 +1749,7 @@ void XMLPrinter::PushDeclaration( const char* value )
if ( elementJustOpened ) {
SealElement();
}
if ( textDepth < 0 && !firstElement) {
if ( textDepth < 0 && !firstElement && !compactMode) {
Print( "\n" );
PrintSpace( depth );
}
@@ -1762,7 +1763,7 @@ void XMLPrinter::PushUnknown( const char* value )
if ( elementJustOpened ) {
SealElement();
}
if ( textDepth < 0 && !firstElement ) {
if ( textDepth < 0 && !firstElement && !compactMode) {
Print( "\n" );
PrintSpace( depth );
}