Commit 30dbe37f authored by unknown's avatar unknown

basestring_vsnprintf fix for size==0

parent a0f3f95e
...@@ -20,6 +20,10 @@ ...@@ -20,6 +20,10 @@
#include <basestring_vsnprintf.h> #include <basestring_vsnprintf.h>
#include <my_config.h> #include <my_config.h>
/*
#define SNPRINTF_RETURN_TRUNC
*/
int int
basestring_snprintf(char *str, size_t size, const char *format, ...) basestring_snprintf(char *str, size_t size, const char *format, ...)
{ {
...@@ -47,13 +51,27 @@ static char basestring_vsnprintf_buf[16*1024]; ...@@ -47,13 +51,27 @@ static char basestring_vsnprintf_buf[16*1024];
int int
basestring_vsnprintf(char *str, size_t size, const char *format, va_list ap) basestring_vsnprintf(char *str, size_t size, const char *format, va_list ap)
{ {
int ret= BASESTRING_VSNPRINTF_FUNC(str, size, format, ap); if (size == 0)
{
#ifdef SNPRINTF_RETURN_TRUNC #ifdef SNPRINTF_RETURN_TRUNC
if (ret == size-1 || ret == -1) { return BASESTRING_VSNPRINTF_FUNC(basestring_vsnprintf_buf,
ret= BASESTRING_VSNPRINTF_FUNC(basestring_vsnprintf_buf, sizeof(basestring_vsnprintf_buf),
sizeof(basestring_vsnprintf_buf), format, ap);
format, ap); #else
char buf[1];
return BASESTRING_VSNPRINTF_FUNC(buf, 1, format, ap);
#endif
} }
{
int ret= BASESTRING_VSNPRINTF_FUNC(str, size, format, ap);
#ifdef SNPRINTF_RETURN_TRUNC
if (ret == size-1 || ret == -1)
{
ret= BASESTRING_VSNPRINTF_FUNC(basestring_vsnprintf_buf,
sizeof(basestring_vsnprintf_buf),
format, ap);
}
#endif #endif
return ret; return ret;
}
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment