WinCE Compatibility Fix
diff --git a/tinyxml2.cpp b/tinyxml2.cpp
index a64dad6..927ec6f 100755
--- a/tinyxml2.cpp
+++ b/tinyxml2.cpp
@@ -1668,7 +1668,7 @@
Clear();
FILE* fp = 0;
-#if defined(_MSC_VER) && (_MSC_VER >= 1400 )
+#if defined(_MSC_VER) && (_MSC_VER >= 1400 ) && (!defined WINCE)
errno_t err = fopen_s(&fp, filename, "rb" );
if ( !fp || err) {
#else
@@ -1729,7 +1729,7 @@
XMLError XMLDocument::SaveFile( const char* filename, bool compact )
{
FILE* fp = 0;
-#if defined(_MSC_VER) && (_MSC_VER >= 1400 )
+#if defined(_MSC_VER) && (_MSC_VER >= 1400 ) && (!defined WINCE)
errno_t err = fopen_s(&fp, filename, "w" );
if ( !fp || err) {
#else
@@ -1856,7 +1856,17 @@
}
else {
#if defined(_MSC_VER) && (_MSC_VER >= 1400 )
+ #if defined(WINCE)
+ int len = 512;
+ do {
+ len = len*2;
+ char* str = new char[len]();
+ len = _vsnprintf(str, len, format, va);
+ delete[] str;
+ }while (len < 0);
+ #else
int len = _vscprintf( format, va );
+ #endif
#else
int len = vsnprintf( 0, 0, format, va );
#endif
@@ -1865,7 +1875,11 @@
va_start( va, format );
char* p = _buffer.PushArr( len ) - 1; // back up over the null terminator.
#if defined(_MSC_VER) && (_MSC_VER >= 1400 )
+ #if defined(WINCE)
+ _vsnprintf( p, len+1, format, va );
+ #else
vsnprintf_s( p, len+1, _TRUNCATE, format, va );
+ #endif
#else
vsnprintf( p, len+1, format, va );
#endif