Loading...
stdio/FreeBSD/fputws.c.patch /dev/null Libc-498
--- /dev/null
+++ Libc/Libc-498/stdio/FreeBSD/fputws.c.patch
@@ -0,0 +1,49 @@
+--- fputws.c.orig	2004-11-25 11:38:34.000000000 -0800
++++ fputws.c	2005-02-23 17:23:49.000000000 -0800
+@@ -27,6 +27,8 @@
+ #include <sys/cdefs.h>
+ __FBSDID("$FreeBSD: src/lib/libc/stdio/fputws.c,v 1.6 2004/07/21 10:54:57 tjr Exp $");
+ 
++#include "xlocale_private.h"
++
+ #include "namespace.h"
+ #include <errno.h>
+ #include <limits.h>
+@@ -39,13 +41,17 @@
+ #include "mblocal.h"
+ 
+ int
+-fputws(const wchar_t * __restrict ws, FILE * __restrict fp)
++fputws_l(const wchar_t * __restrict ws, FILE * __restrict fp, locale_t loc)
+ {
+ 	size_t nbytes;
+ 	char buf[BUFSIZ];
+ 	struct __suio uio;
+ 	struct __siov iov;
++	size_t (*__wcsnrtombs)(char * __restrict, const wchar_t ** __restrict,
++	    size_t, size_t, mbstate_t * __restrict, locale_t);
+ 
++	NORMALIZE_LOCALE(loc);
++	__wcsnrtombs = loc->__lc_ctype->__wcsnrtombs;
+ 	FLOCKFILE(fp);
+ 	ORIENT(fp, 1);
+ 	if (prepwrite(fp) != 0)
+@@ -55,7 +61,7 @@
+ 	iov.iov_base = buf;
+ 	do {
+ 		nbytes = __wcsnrtombs(buf, &ws, SIZE_T_MAX, sizeof(buf),
+-		    &fp->_extra->mbstate);
++		    &fp->_extra->mbstate, loc);
+ 		if (nbytes == (size_t)-1)
+ 			goto error;
+ 		iov.iov_len = uio.uio_resid = nbytes;
+@@ -69,3 +75,9 @@
+ 	FUNLOCKFILE(fp);
+ 	return (-1);
+ }
++
++int
++fputws(const wchar_t * __restrict ws, FILE * __restrict fp)
++{
++	return fputws_l(ws, fp, __current_locale());
++}