Loading...
stdio/FreeBSD/vasprintf.c Libc-1725.40.4 Libc-825.26
--- Libc/Libc-1725.40.4/stdio/FreeBSD/vasprintf.c
+++ Libc/Libc-825.26/stdio/FreeBSD/vasprintf.c
@@ -37,8 +37,12 @@
 #include <errno.h>
 #include "local.h"
 
-__private_extern__ int
-_vasprintf(printf_comp_t __restrict pc, printf_domain_t __restrict domain, char ** __restrict str, locale_t __restrict loc, const char * __restrict fmt, __va_list ap)
+int
+vasprintf_l(str, loc, fmt, ap)
+	char **str;
+	locale_t loc;
+	const char *fmt;
+	__va_list ap;
 {
 	int ret;
 	FILE f;
@@ -46,6 +50,7 @@
 	f._extra = &ext;
 	INITEXTRA(&f);
 	
+	NORMALIZE_LOCALE(loc);
 	f._file = -1;
 	f._flags = __SWR | __SSTR | __SALC;
 	f._bf._base = f._p = (unsigned char *)malloc(128);
@@ -57,7 +62,7 @@
 	f._bf._size = f._w = 127;		/* Leave room for the NUL */
 	f._orientation = 0;
 	memset(&f._mbstate, 0, sizeof(mbstate_t));
-	ret = __v2printf(pc, domain, &f, loc, fmt, ap);
+	ret = __vfprintf(&f, loc, fmt, ap);
 	if (ret < 0) {
 		free(f._bf._base);
 		*str = NULL;
@@ -70,13 +75,10 @@
 }
 
 int
-vasprintf_l(char ** __restrict str, locale_t __restrict loc, const char * __restrict fmt, __va_list ap)
+vasprintf(str, fmt, ap)
+	char **str;
+	const char *fmt;
+	__va_list ap;
 {
-	return _vasprintf(XPRINTF_PLAIN, NULL, str, loc, fmt, ap);
+	return vasprintf_l(str, __current_locale(), fmt, ap);
 }
-
-int
-vasprintf(char ** __restrict str, const char * __restrict fmt, __va_list ap)
-{
-	return _vasprintf(XPRINTF_PLAIN, NULL, str, __current_locale(), fmt, ap);
-}