]> git.saurik.com Git - apple/libc.git/blobdiff - stdio/FreeBSD/fputws.c
Libc-825.25.tar.gz
[apple/libc.git] / stdio / FreeBSD / fputws.c
index 6c4a3330719b77f98d639fc3ae978b5f88ad7fad..1ff04845dcbeb470c2a2dfdb3b5df35ab8c8cae7 100644 (file)
@@ -27,6 +27,8 @@
 #include <sys/cdefs.h>
 __FBSDID("$FreeBSD: src/lib/libc/stdio/fputws.c,v 1.8 2009/01/15 18:53:52 rdivacky Exp $");
 
+#include "xlocale_private.h"
+
 #include "namespace.h"
 #include <errno.h>
 #include <limits.h>
@@ -39,14 +41,18 @@ __FBSDID("$FreeBSD: src/lib/libc/stdio/fputws.c,v 1.8 2009/01/15 18:53:52 rdivac
 #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;
-       const wchar_t *wsp;
+       const wchar_t *wsp = ws;
+       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,15 +61,14 @@ fputws(const wchar_t * __restrict ws, FILE * __restrict fp)
        uio.uio_iovcnt = 1;
        iov.iov_base = buf;
        do {
-               wsp = ws;
                nbytes = __wcsnrtombs(buf, &wsp, SIZE_T_MAX, sizeof(buf),
-                   &fp->_mbstate);
+                   &fp->_mbstate, loc);
                if (nbytes == (size_t)-1)
                        goto error;
                iov.iov_len = uio.uio_resid = nbytes;
                if (__sfvwrite(fp, &uio) != 0)
                        goto error;
-       } while (ws != NULL);
+       } while (wsp != NULL);
        FUNLOCKFILE(fp);
        return (0);
 
@@ -71,3 +76,9 @@ error:
        FUNLOCKFILE(fp);
        return (-1);
 }
+
+int
+fputws(const wchar_t * __restrict ws, FILE * __restrict fp)
+{
+       return fputws_l(ws, fp, __current_locale());
+}