Loading...
stdio/FreeBSD/scanf.c.patch /dev/null Libc-763.13
--- /dev/null
+++ Libc/Libc-763.13/stdio/FreeBSD/scanf.c.patch
@@ -0,0 +1,35 @@
+--- scanf.c.bsdnew	2009-11-11 13:33:15.000000000 -0800
++++ scanf.c	2009-11-11 13:33:15.000000000 -0800
+@@ -36,6 +36,8 @@ static char sccsid[] = "@(#)scanf.c	8.1 
+ #include <sys/cdefs.h>
+ __FBSDID("$FreeBSD: src/lib/libc/stdio/scanf.c,v 1.13 2007/01/09 00:28:07 imp Exp $");
+ 
++#include "xlocale_private.h"
++
+ #include "namespace.h"
+ #include <stdio.h>
+ #include <stdarg.h>
+@@ -51,7 +53,22 @@ scanf(char const * __restrict fmt, ...)
+ 
+ 	va_start(ap, fmt);
+ 	FLOCKFILE(stdin);
+-	ret = __svfscanf(stdin, fmt, ap);
++	ret = __svfscanf_l(stdin, __current_locale(), fmt, ap);
++	FUNLOCKFILE(stdin);
++	va_end(ap);
++	return (ret);
++}
++
++int
++scanf_l(locale_t loc, char const * __restrict fmt, ...)
++{
++	int ret;
++	va_list ap;
++
++	NORMALIZE_LOCALE(loc);
++	va_start(ap, fmt);
++	FLOCKFILE(stdin);
++	ret = __svfscanf_l(stdin, loc, fmt, ap);
+ 	FUNLOCKFILE(stdin);
+ 	va_end(ap);
+ 	return (ret);