Loading...
--- Libc/Libc-763.13/stdio/FreeBSD/vsscanf.c.patch
+++ Libc/Libc-391.2.5/stdio/FreeBSD/vsscanf.c.patch
@@ -1,46 +1,41 @@
---- vsscanf.c.orig 2011-03-01 17:54:44.000000000 -0800
-+++ vsscanf.c 2011-03-01 18:03:46.000000000 -0800
-@@ -36,6 +36,8 @@ static char sccsid[] = "@(#)vsscanf.c 8.
+--- vsscanf.c.orig 2003-05-20 15:22:44.000000000 -0700
++++ vsscanf.c 2005-02-23 16:57:18.000000000 -0800
+@@ -40,6 +40,8 @@
#include <sys/cdefs.h>
- __FBSDID("$FreeBSD: src/lib/libc/stdio/vsscanf.c,v 1.14 2008/04/17 22:17:54 jhb Exp $");
+ __FBSDID("$FreeBSD: src/lib/libc/stdio/vsscanf.c,v 1.12 2002/10/12 16:13:41 mike Exp $");
+#include "xlocale_private.h"
+
#include <stdio.h>
#include <string.h>
#include "local.h"
-@@ -55,12 +57,16 @@ eofread(cookie, buf, len)
- }
-
- int
--vsscanf(str, fmt, ap)
-+vsscanf_l(str, loc, fmt, ap)
- const char * __restrict str;
-+ locale_t loc;
- const char * __restrict fmt;
- __va_list ap;
- {
- FILE f;
-+ struct __sFILEX ext;
-+ f._extra = &ext;
-+ INITEXTRA(&f);
-
- f._file = -1;
- f._flags = __SRD;
-@@ -71,5 +77,15 @@ vsscanf(str, fmt, ap)
+@@ -76,5 +78,28 @@
f._lb._base = NULL;
- f._orientation = 0;
- memset(&f._mbstate, 0, sizeof(mbstate_t));
+ f._extra = &ext;
+ INITEXTRA(&f);
- return (__svfscanf(&f, fmt, ap));
-+ return (__svfscanf_l(&f, loc, fmt, ap));
- }
++ return (__svfscanf_l(&f, __current_locale(), fmt, ap));
++}
+
+int
-+vsscanf(str, fmt, ap)
++vsscanf_l(str, loc, fmt, ap)
+ const char * __restrict str;
++ locale_t loc;
+ const char * __restrict fmt;
+ __va_list ap;
+{
-+ return vsscanf_l(str, __current_locale(), fmt, ap);
-+}
++ FILE f;
++ struct __sFILEX ext;
+
++ NORMALIZE_LOCALE(loc);
++ f._file = -1;
++ f._flags = __SRD;
++ f._bf._base = f._p = (unsigned char *)str;
++ f._bf._size = f._r = strlen(str);
++ f._read = eofread;
++ f._ub._base = NULL;
++ f._lb._base = NULL;
++ f._extra = &ext;
++ INITEXTRA(&f);
++ return (__svfscanf_l(&f, loc, fmt, ap));
+ }