Loading...
stdio/FreeBSD/scanf.c.patch /dev/null Libc-391
--- /dev/null
+++ Libc/Libc-391/stdio/FreeBSD/scanf.c.patch
@@ -0,0 +1,35 @@
+--- scanf.c.orig	2003-05-20 15:22:43.000000000 -0700
++++ scanf.c	2005-02-23 16:37:59.000000000 -0800
+@@ -40,6 +40,8 @@
+ #include <sys/cdefs.h>
+ __FBSDID("$FreeBSD: src/lib/libc/stdio/scanf.c,v 1.12 2003/01/03 23:27:27 tjr Exp $");
+ 
++#include "xlocale_private.h"
++
+ #include "namespace.h"
+ #include <stdio.h>
+ #include <stdarg.h>
+@@ -55,7 +57,22 @@
+ 
+ 	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);