Commit 663c21d4 authored by Ronald S. Bultje's avatar Ronald S. Bultje Committed by Derek Buitenhuis

compat/vsnprintf: return number of bytes required on truncation.

This conforms to C99, but requires Windows >= XP.
parent e1b44960
...@@ -43,9 +43,10 @@ int avpriv_vsnprintf(char *s, size_t n, const char *fmt, ...@@ -43,9 +43,10 @@ int avpriv_vsnprintf(char *s, size_t n, const char *fmt,
va_list ap) va_list ap)
{ {
int ret; int ret;
va_list ap_copy;
if (n == 0) if (n == 0)
return 0; return _vscprintf(fmt, ap);
else if (n > INT_MAX) else if (n > INT_MAX)
return AVERROR(EOVERFLOW); return AVERROR(EOVERFLOW);
...@@ -56,9 +57,11 @@ int avpriv_vsnprintf(char *s, size_t n, const char *fmt, ...@@ -56,9 +57,11 @@ int avpriv_vsnprintf(char *s, size_t n, const char *fmt,
* _snprintf/_vsnprintf() to workaround this problem. * _snprintf/_vsnprintf() to workaround this problem.
* See http://msdn.microsoft.com/en-us/library/1kt27hek(v=vs.80).aspx */ * See http://msdn.microsoft.com/en-us/library/1kt27hek(v=vs.80).aspx */
memset(s, 0, n); memset(s, 0, n);
ret = _vsnprintf(s, n - 1, fmt, ap); va_copy(ap_copy, ap);
ret = _vsnprintf(s, n - 1, fmt, ap_copy);
va_end(ap_copy);
if (ret == -1) if (ret == -1)
ret = n; ret = _vscprintf(fmt, ap);
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