X-Git-Url: https://git.saurik.com/apple/libc.git/blobdiff_plain/1f2f436a38f7ae2d39a943ad2898d8fed4ed2e58..refs/heads/master:/stdio/FreeBSD/vsnprintf.c diff --git a/stdio/FreeBSD/vsnprintf.c b/stdio/FreeBSD/vsnprintf.c index 1a20c99..4b29144 100644 --- a/stdio/FreeBSD/vsnprintf.c +++ b/stdio/FreeBSD/vsnprintf.c @@ -36,24 +36,35 @@ static char sccsid[] = "@(#)vsnprintf.c 8.1 (Berkeley) 6/4/93"; #include __FBSDID("$FreeBSD: src/lib/libc/stdio/vsnprintf.c,v 1.24 2008/04/17 22:17:54 jhb Exp $"); +#include "xlocale_private.h" + #include #include #include "local.h" -int -vsnprintf(char * __restrict str, size_t n, const char * __restrict fmt, - __va_list ap) +__private_extern__ int +_vsnprintf(printf_comp_t __restrict pc, printf_domain_t __restrict domain, char * __restrict str, size_t n, locale_t __restrict loc, const char * __restrict fmt, __va_list ap) { size_t on; int ret; char dummy[2]; FILE f; + struct __sFILEX ext; + f._extra = &ext; + INITEXTRA(&f); on = n; if (n != 0) n--; +#if defined(__i386__) + /* don't corrupt the output buffer at all if the size underflowed */ + if (n > INT_MAX) + on = n = 0; +#else if (n > INT_MAX) n = INT_MAX; +#endif + /* Stdio internals do not deal correctly with zero length buffer */ if (n == 0) { if (on > 0) @@ -67,8 +78,21 @@ vsnprintf(char * __restrict str, size_t n, const char * __restrict fmt, f._bf._size = f._w = n; f._orientation = 0; memset(&f._mbstate, 0, sizeof(mbstate_t)); - ret = __vfprintf(&f, fmt, ap); + ret = __v2printf(pc, domain, &f, loc, fmt, ap); if (on > 0) *f._p = '\0'; return (ret); } +int +vsnprintf_l(char * __restrict str, size_t n, locale_t __restrict loc, const char * __restrict fmt, + __va_list ap) +{ + return _vsnprintf(XPRINTF_PLAIN, NULL, str, n, loc, fmt, ap); +} + +int +vsnprintf(char * __restrict str, size_t n, const char * __restrict fmt, + __va_list ap) +{ + return _vsnprintf(XPRINTF_PLAIN, NULL, str, n, __current_locale(), fmt, ap); +}