diff --git a/Makefile b/Makefile
index b1a8ed7..aab6293 100644
--- a/Makefile
+++ b/Makefile
@@ -1,4 +1,6 @@
all: xmltest
xmltest: xmltest.cpp tinyxml2.cpp tinyxml2.h
+test: clean xmltest
+ ./xmltest
clean:
rm -f *.o xmltest
diff --git a/readme.md b/readme.md
index 40e37bc..c29ce33 100644
--- a/readme.md
+++ b/readme.md
@@ -2,7 +2,7 @@ TinyXML-2
=========
![TinyXML-2 Logo](http://www.grinninglizard.com/tinyxml2/TinyXML2_small.png)
-TinyXML is a simple, small, efficient, C++ XML parser that can be
+TinyXML-2 is a simple, small, efficient, C++ XML parser that can be
easily integrated into other programs.
The master is hosted on github:
@@ -16,7 +16,7 @@ Examples are in the "related pages" tab of the HTML docs.
What it does.
-------------
-In brief, TinyXML parses an XML document, and builds from that a
+In brief, TinyXML-2 parses an XML document, and builds from that a
Document Object Model (DOM) that can be read, modified, and saved.
XML stands for "eXtensible Markup Language." It is a general purpose
@@ -198,7 +198,7 @@ Or the XMLPrinter class:
Printing to memory is supported by the XMLPrinter.
XMLPrinter printer;
- doc->Print( &printer );
+ doc.Print( &printer );
// printer.CStr() has a const char* to the XML
#### Print without an XMLDocument
diff --git a/tinyxml2.cpp b/tinyxml2.cpp
index ad00867..5611614 100755
--- a/tinyxml2.cpp
+++ b/tinyxml2.cpp
@@ -1691,7 +1691,7 @@ XMLError XMLDocument::Parse( const char* p, size_t len )
}
-void XMLDocument::Print( XMLPrinter* streamer )
+void XMLDocument::Print( XMLPrinter* streamer ) const
{
XMLPrinter stdStreamer( stdout );
if ( !streamer ) {
@@ -1729,11 +1729,11 @@ void XMLDocument::PrintError() const
}
-XMLPrinter::XMLPrinter( FILE* file, bool compact ) :
+XMLPrinter::XMLPrinter( FILE* file, bool compact, int depth ) :
_elementJustOpened( false ),
_firstElement( true ),
_fp( file ),
- _depth( 0 ),
+ _depth( depth ),
_textDepth( -1 ),
_processEntities( true ),
_compactMode( compact )
@@ -1839,8 +1839,8 @@ void XMLPrinter::PrintString( const char* p, bool restricted )
void XMLPrinter::PushHeader( bool writeBOM, bool writeDec )
{
- static const unsigned char bom[] = { TIXML_UTF_LEAD_0, TIXML_UTF_LEAD_1, TIXML_UTF_LEAD_2, 0 };
if ( writeBOM ) {
+ static const unsigned char bom[] = { TIXML_UTF_LEAD_0, TIXML_UTF_LEAD_1, TIXML_UTF_LEAD_2, 0 };
Print( "%s", bom );
}
if ( writeDec ) {
@@ -1858,6 +1858,8 @@ void XMLPrinter::OpenElement( const char* name )
if ( _textDepth < 0 && !_firstElement && !_compactMode ) {
Print( "\n" );
+ }
+ if ( !_compactMode ) {
PrintSpace( _depth );
}
diff --git a/tinyxml2.h b/tinyxml2.h
index 9c7e6e9..adda85a 100755
--- a/tinyxml2.h
+++ b/tinyxml2.h
@@ -14,6 +14,7 @@ not claim that you wrote the original software. If you use this
software in a product, an acknowledgment in the product documentation
would be appreciated but is not required.
+
2. Altered source versions must be plainly marked as such, and
must not be misrepresented as being the original software.
@@ -57,6 +58,23 @@ distribution.
# endif
#endif
+#ifdef _MSC_VER
+# pragma warning(push)
+# pragma warning(disable: 4251)
+#endif
+
+#ifdef _WIN32
+# ifdef TINYXML2_EXPORT
+# define TINYXML2_LIB __declspec(dllexport)
+# elif defined(TINYXML2_IMPORT)
+# define TINYXML2_LIB __declspec(dllimport)
+# else
+# define TINYXML2_LIB
+# endif
+#else
+# define TINYXML2_LIB
+#endif
+
#if defined(DEBUG)
# if defined(_MSC_VER)
@@ -108,11 +126,9 @@ class XMLDocument;
class XMLElement;
class XMLAttribute;
class XMLComment;
-class XMLNode;
class XMLText;
class XMLDeclaration;
class XMLUnknown;
-
class XMLPrinter;
/*
@@ -402,13 +418,13 @@ private:
All flavors of Visit methods have a default implementation that returns 'true' (continue
visiting). You need to only override methods that are interesting to you.
- Generally Accept() is called on the TiXmlDocument, although all nodes support visiting.
+ Generally Accept() is called on the XMLDocument, although all nodes support visiting.
You should never change the document from a callback.
@sa XMLNode::Accept()
*/
-class XMLVisitor
+class TINYXML2_LIB XMLVisitor
{
public:
virtual ~XMLVisitor() {}
@@ -554,7 +570,7 @@ public:
@endverbatim
*/
-class XMLNode
+class TINYXML2_LIB XMLNode
{
friend class XMLDocument;
friend class XMLElement;
@@ -759,12 +775,12 @@ public:
*/
virtual bool ShallowEqual( const XMLNode* compare ) const = 0;
- /** Accept a hierarchical visit of the nodes in the TinyXML DOM. Every node in the
+ /** Accept a hierarchical visit of the nodes in the TinyXML-2 DOM. Every node in the
XML tree will be conditionally visited and the host will be called back
- via the TiXmlVisitor interface.
+ via the XMLVisitor interface.
- This is essentially a SAX interface for TinyXML. (Note however it doesn't re-parse
- the XML for the callbacks, so the performance of TinyXML is unchanged by using this
+ This is essentially a SAX interface for TinyXML-2. (Note however it doesn't re-parse
+ the XML for the callbacks, so the performance of TinyXML-2 is unchanged by using this
interface versus any other.)
The interface has been based on ideas from:
@@ -776,7 +792,7 @@ public:
An example of using Accept():
@verbatim
- TiXmlPrinter printer;
+ XMLPrinter printer;
tinyxmlDoc.Accept( &printer );
const char* xmlcstr = printer.CStr();
@endverbatim
@@ -818,9 +834,9 @@ private:
A text node can have 2 ways to output the next. "normal" output
and CDATA. It will default to the mode it was parsed from the XML file and
you generally want to leave it alone, but you can change the output mode with
- SetCDATA() and query it with CDATA().
+ SetCData() and query it with CData().
*/
-class XMLText : public XMLNode
+class TINYXML2_LIB XMLText : public XMLNode
{
friend class XMLBase;
friend class XMLDocument;
@@ -859,7 +875,7 @@ private:
/** An XML Comment. */
-class XMLComment : public XMLNode
+class TINYXML2_LIB XMLComment : public XMLNode
{
friend class XMLDocument;
public:
@@ -891,13 +907,13 @@ private:
@endverbatim
- TinyXML2 will happily read or write files without a declaration,
+ TinyXML-2 will happily read or write files without a declaration,
however.
The text of the declaration isn't interpreted. It is parsed
and written as a string.
*/
-class XMLDeclaration : public XMLNode
+class TINYXML2_LIB XMLDeclaration : public XMLNode
{
friend class XMLDocument;
public:
@@ -922,14 +938,14 @@ protected:
};
-/** Any tag that tinyXml doesn't recognize is saved as an
+/** Any tag that TinyXML-2 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.
+ DTD tags get thrown into XMLUnknowns.
*/
-class XMLUnknown : public XMLNode
+class TINYXML2_LIB XMLUnknown : public XMLNode
{
friend class XMLDocument;
public:
@@ -988,7 +1004,7 @@ enum XMLError {
@note The attributes are not XMLNodes. You may only query the
Next() attribute in a list.
*/
-class XMLAttribute
+class TINYXML2_LIB XMLAttribute
{
friend class XMLElement;
public:
@@ -1005,52 +1021,52 @@ public:
return _next;
}
- /** IntAttribute interprets the attribute as an integer, and returns the value.
+ /** IntValue interprets the attribute as an integer, and returns the value.
If the value isn't an integer, 0 will be returned. There is no error checking;
- use QueryIntAttribute() if you need error checking.
+ use QueryIntValue() if you need error checking.
*/
int IntValue() const {
int i=0;
QueryIntValue( &i );
return i;
}
- /// Query as an unsigned integer. See IntAttribute()
+ /// Query as an unsigned integer. See IntValue()
unsigned UnsignedValue() const {
unsigned i=0;
QueryUnsignedValue( &i );
return i;
}
- /// Query as a boolean. See IntAttribute()
+ /// Query as a boolean. See IntValue()
bool BoolValue() const {
bool b=false;
QueryBoolValue( &b );
return b;
}
- /// Query as a double. See IntAttribute()
+ /// Query as a double. See IntValue()
double DoubleValue() const {
double d=0;
QueryDoubleValue( &d );
return d;
}
- /// Query as a float. See IntAttribute()
+ /// Query as a float. See IntValue()
float FloatValue() const {
float f=0;
QueryFloatValue( &f );
return f;
}
- /** QueryIntAttribute interprets the attribute as an integer, and returns the value
+ /** QueryIntValue interprets the attribute as an integer, and returns the value
in the provided parameter. The function will return XML_NO_ERROR on success,
and XML_WRONG_ATTRIBUTE_TYPE if the conversion is not successful.
*/
XMLError QueryIntValue( int* value ) const;
- /// See QueryIntAttribute
+ /// See QueryIntValue
XMLError QueryUnsignedValue( unsigned int* value ) const;
- /// See QueryIntAttribute
+ /// See QueryIntValue
XMLError QueryBoolValue( bool* value ) const;
- /// See QueryIntAttribute
+ /// See QueryIntValue
XMLError QueryDoubleValue( double* value ) const;
- /// See QueryIntAttribute
+ /// See QueryIntValue
XMLError QueryFloatValue( float* value ) const;
/// Set the attribute to a string value.
@@ -1089,7 +1105,7 @@ private:
and can contain other elements, text, comments, and unknowns.
Elements also contain an arbitrary number of attributes.
*/
-class XMLElement : public XMLNode
+class TINYXML2_LIB XMLElement : public XMLNode
{
friend class XMLBase;
friend class XMLDocument;
@@ -1301,10 +1317,10 @@ public:
const XMLAttribute* FindAttribute( const char* name ) const;
/** Convenience function for easy access to the text inside an element. Although easy
- and concise, GetText() is limited compared to getting the TiXmlText child
+ and concise, GetText() is limited compared to getting the XMLText child
and accessing it directly.
- If the first child of 'this' is a TiXmlText, the GetText()
+ If the first child of 'this' is a XMLText, the GetText()
returns the character string of the Text node, else null is returned.
This is a convenient method for getting the text of simple contained text:
@@ -1409,7 +1425,7 @@ enum Whitespace {
All Nodes are connected and allocated to a Document.
If the Document is deleted, all its Nodes are also deleted.
*/
-class XMLDocument : public XMLNode
+class TINYXML2_LIB XMLDocument : public XMLNode
{
friend class XMLElement;
public:
@@ -1431,7 +1447,7 @@ public:
You may optionally pass in the 'nBytes', which is
the number of bytes which will be parsed. If not
- specified, TinyXML will assume 'xml' points to a
+ specified, TinyXML-2 will assume 'xml' points to a
null terminated string.
*/
XMLError Parse( const char* xml, size_t nBytes=(size_t)(-1) );
@@ -1507,11 +1523,11 @@ public:
Or you can use a printer to print to memory:
@verbatim
XMLPrinter printer;
- doc->Print( &printer );
+ doc.Print( &printer );
// printer.CStr() has a const char* to the XML
@endverbatim
*/
- void Print( XMLPrinter* streamer=0 );
+ void Print( XMLPrinter* streamer=0 ) const;
virtual bool Accept( XMLVisitor* visitor ) const;
/**
@@ -1614,7 +1630,7 @@ private:
/**
A XMLHandle is a class that wraps a node pointer with null checks; this is
- an incredibly useful thing. Note that XMLHandle is not part of the TinyXML
+ an incredibly useful thing. Note that XMLHandle is not part of the TinyXML-2
DOM structure. It is a separate utility class.
Take an example:
@@ -1667,7 +1683,7 @@ private:
See also XMLConstHandle, which is the same as XMLHandle, but operates on const objects.
*/
-class XMLHandle
+class TINYXML2_LIB XMLHandle
{
public:
/// Create a handle from any node (at any depth of the tree.) This can be a null pointer.
@@ -1751,7 +1767,7 @@ private:
A variant of the XMLHandle class for working with const XMLNodes and Documents. It is the
same in all regards, except for the 'const' qualifiers. See XMLHandle for API.
*/
-class XMLConstHandle
+class TINYXML2_LIB XMLConstHandle
{
public:
XMLConstHandle( const XMLNode* node ) {
@@ -1829,7 +1845,7 @@ private:
@verbatim
XMLPrinter printer;
- doc->Print( &printer );
+ doc.Print( &printer );
SomeFunction( printer.CStr() );
@endverbatim
@@ -1858,7 +1874,7 @@ private:
printer.CloseElement();
@endverbatim
*/
-class XMLPrinter : public XMLVisitor
+class TINYXML2_LIB XMLPrinter : public XMLVisitor
{
public:
/** Construct the printer. If the FILE* is specified,
@@ -1867,7 +1883,7 @@ public:
If 'compact' is set to true, then output is created
with only required whitespace and newlines.
*/
- XMLPrinter( FILE* file=0, bool compact = false );
+ XMLPrinter( FILE* file=0, bool compact = false, int depth = 0 );
~XMLPrinter() {}
/** If streaming, write the BOM and declaration. */
@@ -1964,5 +1980,8 @@ private:
} // tinyxml2
+#if defined(_MSC_VER)
+# pragma warning(pop)
+#endif
#endif // TINYXML2_INCLUDED
diff --git a/tinyxml2/test.vcxproj b/tinyxml2/test.vcxproj
new file mode 100644
index 0000000..e61bb1b
--- /dev/null
+++ b/tinyxml2/test.vcxproj
@@ -0,0 +1,347 @@
+
+
+
+
+ Debug-Dll
+ Win32
+
+
+ Debug-Dll
+ x64
+
+
+ Debug-Lib
+ Win32
+
+
+ Debug-Lib
+ x64
+
+
+ Release-Dll
+ Win32
+
+
+ Release-Dll
+ x64
+
+
+ Release-Lib
+ Win32
+
+
+ Release-Lib
+ x64
+
+
+
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}
+ test
+
+
+
+ Application
+ true
+ Unicode
+
+
+ Application
+ true
+ Unicode
+
+
+ Application
+ true
+ Unicode
+
+
+ Application
+ true
+ Unicode
+
+
+ Application
+ false
+ true
+ Unicode
+
+
+ Application
+ false
+ true
+ Unicode
+
+
+ Application
+ false
+ true
+ Unicode
+
+
+ Application
+ false
+ true
+ Unicode
+
+
+ Unicode
+
+
+ Unicode
+ true
+
+
+ Unicode
+
+
+ Unicode
+ true
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+
+
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+
+ Level4
+ Disabled
+
+
+ true
+
+
+
+
+ Level4
+ Disabled
+
+
+ true
+
+
+
+
+ Level4
+ Disabled
+ TINYXML2_IMPORT;%(PreprocessorDefinitions)
+
+
+ true
+ Console
+
+
+
+
+ Level4
+ Disabled
+ TINYXML2_IMPORT;%(PreprocessorDefinitions)
+
+
+ true
+ Console
+
+
+
+
+ Level4
+ MaxSpeed
+ true
+ true
+
+
+ true
+ true
+ true
+
+
+
+
+ Level4
+ MaxSpeed
+ true
+ true
+
+
+ true
+ true
+ true
+
+
+
+
+ Level4
+ MaxSpeed
+ true
+ true
+ AnySuitable
+ Speed
+ true
+ true
+ true
+ TINYXML2_IMPORT;%(PreprocessorDefinitions)
+
+
+ false
+ true
+ true
+ Console
+ true
+
+
+
+
+ Level4
+ MaxSpeed
+ true
+ true
+ AnySuitable
+ Speed
+ true
+ true
+ true
+ TINYXML2_IMPORT;%(PreprocessorDefinitions)
+
+
+ false
+ true
+ true
+ Console
+ true
+
+
+
+
+ Level4
+
+
+ Console
+
+
+
+
+ Level4
+ AnySuitable
+ true
+ Speed
+ true
+ true
+ true
+
+
+ false
+ Console
+ true
+ true
+ true
+
+
+
+
+ Level4
+
+
+ Console
+
+
+
+
+ Level4
+ AnySuitable
+ true
+ Speed
+ true
+ true
+ true
+
+
+ false
+ Console
+ true
+ true
+ true
+
+
+
+
+
+
+
+ {d1c528b6-aa02-4d29-9d61-dc08e317a70d}
+
+
+
+
+
+
\ No newline at end of file
diff --git a/tinyxml2/test.vcxproj.filters b/tinyxml2/test.vcxproj.filters
new file mode 100644
index 0000000..0a70dc6
--- /dev/null
+++ b/tinyxml2/test.vcxproj.filters
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/tinyxml2/tinyxml2.sln b/tinyxml2/tinyxml2.sln
index 24d5ce6..1c0c92f 100755
--- a/tinyxml2/tinyxml2.sln
+++ b/tinyxml2/tinyxml2.sln
@@ -1,18 +1,54 @@
Microsoft Visual Studio Solution File, Format Version 11.00
-# Visual C++ Express 2010
+# Visual Studio 2010
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tinyxml2", "tinyxml2.vcxproj", "{D1C528B6-AA02-4D29-9D61-DC08E317A70D}"
EndProject
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "test", "test.vcxproj", "{E8FB2712-8666-4662-A5B8-2B5B0FB1A260}"
+EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
- Debug|Win32 = Debug|Win32
- Release|Win32 = Release|Win32
+ Debug-Dll|Win32 = Debug-Dll|Win32
+ Debug-Dll|x64 = Debug-Dll|x64
+ Debug-Lib|Win32 = Debug-Lib|Win32
+ Debug-Lib|x64 = Debug-Lib|x64
+ Release-Dll|Win32 = Release-Dll|Win32
+ Release-Dll|x64 = Release-Dll|x64
+ Release-Lib|Win32 = Release-Lib|Win32
+ Release-Lib|x64 = Release-Lib|x64
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
- {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug|Win32.ActiveCfg = Debug|Win32
- {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug|Win32.Build.0 = Debug|Win32
- {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release|Win32.ActiveCfg = Release|Win32
- {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release|Win32.Build.0 = Release|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Dll|Win32.ActiveCfg = Debug-Dll|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Dll|Win32.Build.0 = Debug-Dll|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Dll|x64.ActiveCfg = Debug-Dll|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Dll|x64.Build.0 = Debug-Dll|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Lib|Win32.ActiveCfg = Debug-Lib|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Lib|Win32.Build.0 = Debug-Lib|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Lib|x64.ActiveCfg = Debug-Lib|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Debug-Lib|x64.Build.0 = Debug-Lib|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Dll|Win32.ActiveCfg = Release-Dll|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Dll|Win32.Build.0 = Release-Dll|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Dll|x64.ActiveCfg = Release-Dll|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Dll|x64.Build.0 = Release-Dll|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Lib|Win32.ActiveCfg = Release-Lib|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Lib|Win32.Build.0 = Release-Lib|Win32
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Lib|x64.ActiveCfg = Release-Lib|x64
+ {D1C528B6-AA02-4D29-9D61-DC08E317A70D}.Release-Lib|x64.Build.0 = Release-Lib|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Dll|Win32.ActiveCfg = Debug-Dll|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Dll|Win32.Build.0 = Debug-Dll|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Dll|x64.ActiveCfg = Debug-Dll|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Dll|x64.Build.0 = Debug-Dll|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Lib|Win32.ActiveCfg = Debug-Lib|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Lib|Win32.Build.0 = Debug-Lib|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Lib|x64.ActiveCfg = Debug-Lib|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Debug-Lib|x64.Build.0 = Debug-Lib|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Dll|Win32.ActiveCfg = Release-Dll|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Dll|Win32.Build.0 = Release-Dll|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Dll|x64.ActiveCfg = Release-Dll|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Dll|x64.Build.0 = Release-Dll|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Lib|Win32.ActiveCfg = Release-Lib|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Lib|Win32.Build.0 = Release-Lib|Win32
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Lib|x64.ActiveCfg = Release-Lib|x64
+ {E8FB2712-8666-4662-A5B8-2B5B0FB1A260}.Release-Lib|x64.Build.0 = Release-Lib|x64
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
diff --git a/tinyxml2/tinyxml2.vcxproj b/tinyxml2/tinyxml2.vcxproj
index d13b5c6..7155976 100755
--- a/tinyxml2/tinyxml2.vcxproj
+++ b/tinyxml2/tinyxml2.vcxproj
@@ -1,14 +1,38 @@
-
- Debug
+
+ Debug-Dll
Win32
-
- Release
+
+ Debug-Dll
+ x64
+
+
+ Debug-Lib
Win32
+
+ Debug-Lib
+ x64
+
+
+ Release-Dll
+ Win32
+
+
+ Release-Dll
+ x64
+
+
+ Release-Lib
+ Win32
+
+
+ Release-Lib
+ x64
+
{D1C528B6-AA02-4D29-9D61-DC08E317A70D}
@@ -16,38 +40,141 @@
tinyxml2
-
- Application
+
+ StaticLibrary
true
Unicode
-
- Application
+
+ DynamicLibrary
+ true
+ Unicode
+
+
+ StaticLibrary
+ true
+ Unicode
+
+
+ DynamicLibrary
+ true
+ Unicode
+
+
+ StaticLibrary
false
true
Unicode
+
+ DynamicLibrary
+ false
+ true
+ Unicode
+
+
+ StaticLibrary
+ false
+ true
+ Unicode
+
+
+ DynamicLibrary
+ false
+ true
+ Unicode
+
+
+ StaticLibrary
+ Unicode
+
+
+ StaticLibrary
+ true
+ Unicode
+
+
+ StaticLibrary
+ Unicode
+
+
+ StaticLibrary
+ true
+ Unicode
+
-
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
+
true
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
-
+
+ true
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ true
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ true
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
false
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
-
+
+ false
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ false
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
+ false
+ $(SolutionDir)bin\$(Platform)-$(Configuration)\
+ $(SolutionDir)temp\$(Platform)-$(Configuration)\
+
+
- Level3
+ Level4
Disabled
WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
@@ -56,30 +183,200 @@
true
-
+
- Level3
+
+
+ Level4
+ Disabled
+ WIN32;TINYXML2_EXPORT;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+
+
+ NotSet
+ true
+
+
+
+
+
+
+ Level4
+ Disabled
+ WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+
+
+ Console
+ true
+
+
+
+
+
+
+ Level4
+ Disabled
+ WIN32;TINYXML2_EXPORT;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+
+
+ NotSet
+ true
+
+
+
+
+ Level4
MaxSpeed
true
true
WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ AnySuitable
+ Speed
+ true
+ true
+ true
+ false
Console
true
true
true
+ true
+
+
+ Level4
+
+
+ MaxSpeed
+ true
+ true
+ WIN32;TINYXML2_EXPORT;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ AnySuitable
+ Speed
+ true
+ true
+ true
+ false
+
+
+ NotSet
+ true
+ true
+ true
+ true
+
+
+
+
+ Level4
+
+
+ MaxSpeed
+ true
+ true
+ WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ AnySuitable
+ Speed
+ true
+ true
+ true
+ false
+
+
+ Console
+ true
+ true
+ true
+ true
+
+
+
+
+ Level4
+
+
+ MaxSpeed
+ true
+ true
+ WIN32;TINYXML2_EXPORT;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ AnySuitable
+ Speed
+ true
+ true
+ true
+ false
+
+
+ NotSet
+ true
+ true
+ true
+ true
+
+
+
+
+ true
+
+
+
+
+ true
+
+
+ AnySuitable
+
+
+ true
+
+
+ Speed
+
+
+ true
+
+
+ true
+ true
+ false
+
+
+
+
+ true
+
+
+
+
+ true
+
+
+ AnySuitable
+
+
+ true
+
+
+ Speed
+
+
+ true
+
+
+ true
+ true
+ false
+
+
-
-
diff --git a/tinyxml2/tinyxml2.vcxproj.filters b/tinyxml2/tinyxml2.vcxproj.filters
index 89f9d69..e19968a 100755
--- a/tinyxml2/tinyxml2.vcxproj.filters
+++ b/tinyxml2/tinyxml2.vcxproj.filters
@@ -2,10 +2,8 @@
-
-
\ No newline at end of file
diff --git a/xmltest.cpp b/xmltest.cpp
index abb2f1b..86b4ba2 100644
--- a/xmltest.cpp
+++ b/xmltest.cpp
@@ -1262,5 +1262,6 @@ int main( int argc, const char ** argv )
#endif
printf ("\nPass %d, Fail %d\n", gPass, gFail);
- return 0;
+
+ return gFail;
}