diff options
author | madmaxoft <github@xoft.cz> | 2014-01-16 09:01:12 +0100 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2014-01-16 09:01:12 +0100 |
commit | 6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7 (patch) | |
tree | 4fae67ab73ed9a2b18f0127c650b9488bdf97732 /src | |
parent | Another VarArgs fix. (diff) | |
download | cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.tar cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.tar.gz cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.tar.bz2 cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.tar.lz cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.tar.xz cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.tar.zst cuberite-6f739359e33a3d1c1c7ffc1fc2e5116f8c02fcc7.zip |
Diffstat (limited to '')
-rw-r--r-- | src/StringUtils.cpp | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/src/StringUtils.cpp b/src/StringUtils.cpp index 58101779a..0dbd41c12 100644 --- a/src/StringUtils.cpp +++ b/src/StringUtils.cpp @@ -14,23 +14,22 @@ #pragma comment(lib, "ws2_32.lib") #endif -// For platforms that don't have va_copy, define out own, simplistic one: -#ifndef va_copy - #define va_copy(dst, src) dst = src -#endif va_copy - -AString & AppendVPrintf(AString & str, const char *format, va_list args) +AString & AppendVPrintf(AString & str, const char * format, va_list args) { ASSERT(format != NULL); char buffer[2048]; size_t len; + #ifdef va_copy va_list argsCopy; va_copy(argsCopy, args); + #else + #define argsCopy args + #endif #ifdef _MSC_VER // MS CRT provides secure printf that doesn't behave like in the C99 standard if ((len = _vsnprintf_s(buffer, ARRAYCOUNT(buffer), _TRUNCATE, format, argsCopy)) != -1) @@ -39,27 +38,31 @@ AString & AppendVPrintf(AString & str, const char *format, va_list args) #endif // else _MSC_VER { // The result did fit into the static buffer + #ifdef va_copy va_end(argsCopy); + #endif str.append(buffer, len); return str; } + #ifdef va_copy va_end(argsCopy); + #endif // The result did not fit into the static buffer, use a dynamic buffer: #ifdef _MSC_VER // for MS CRT, we need to calculate the result length - va_copy(argsCopy, args); - len = _vscprintf(format, argsCopy); + // MS doesn't have va_copy() and does nod need it at all + len = _vscprintf(format, args); if (len == -1) { - va_end(argsCopy); return str; } - va_end(argsCopy); #endif // _MSC_VER // Allocate a buffer and printf into it: + #ifdef va_copy va_copy(argsCopy, args); + #endif std::vector<char> Buffer(len + 1); #ifdef _MSC_VER vsprintf_s((char *)&(Buffer.front()), Buffer.size(), format, argsCopy); @@ -67,7 +70,9 @@ AString & AppendVPrintf(AString & str, const char *format, va_list args) vsnprintf((char *)&(Buffer.front()), Buffer.size(), format, argsCopy); #endif // else _MSC_VER str.append(&(Buffer.front()), Buffer.size() - 1); + #ifdef va_copy va_end(argsCopy); + #endif return str; } |