]> git.saurik.com Git - apple/libc.git/blobdiff - stdio/FreeBSD/fputwc.c
Libc-997.1.1.tar.gz
[apple/libc.git] / stdio / FreeBSD / fputwc.c
index dfe876f85fc81933b085b4245636b335f300de7f..e835bc27d5a83af61148fe79bd9f9207fc279c1f 100644 (file)
@@ -25,7 +25,9 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/stdio/fputwc.c,v 1.10 2004/07/20 08:27:27 tjr Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/stdio/fputwc.c,v 1.11 2008/04/17 22:17:53 jhb Exp $");
+
+#include "xlocale_private.h"
 
 #include "namespace.h"
 #include <errno.h>
@@ -41,13 +43,14 @@ __FBSDID("$FreeBSD: src/lib/libc/stdio/fputwc.c,v 1.10 2004/07/20 08:27:27 tjr E
 /*
  * Non-MT-safe version.
  */
-wint_t
-__fputwc(wchar_t wc, FILE *fp)
+__private_extern__ wint_t
+__fputwc(wchar_t wc, FILE *fp, locale_t loc)
 {
        char buf[MB_LEN_MAX];
        size_t i, len;
+       struct __xlocale_st_runelocale *xrl = loc->__lc_ctype;
 
-       if (MB_CUR_MAX == 1 && wc > 0 && wc <= UCHAR_MAX) {
+       if (xrl->__mb_cur_max == 1 && wc > 0 && wc <= UCHAR_MAX) {
                /*
                 * Assume single-byte locale with no special encoding.
                 * A more careful test would be to check
@@ -56,8 +59,7 @@ __fputwc(wchar_t wc, FILE *fp)
                *buf = (unsigned char)wc;
                len = 1;
        } else {
-               if ((len = __wcrtomb(buf, wc, &fp->_extra->mbstate)) ==
-                   (size_t)-1) {
+               if ((len = loc->__lc_ctype->__wcrtomb(buf, wc, &fp->_mbstate, loc)) == (size_t)-1) {
                        fp->_flags |= __SERR;
                        return (WEOF);
                }
@@ -80,7 +82,21 @@ fputwc(wchar_t wc, FILE *fp)
 
        FLOCKFILE(fp);
        ORIENT(fp, 1);
-       r = __fputwc(wc, fp);
+       r = __fputwc(wc, fp, __current_locale());
+       FUNLOCKFILE(fp);
+
+       return (r);
+}
+
+wint_t
+fputwc_l(wchar_t wc, FILE *fp, locale_t loc)
+{
+       wint_t r;
+
+       NORMALIZE_LOCALE(loc);
+       FLOCKFILE(fp);
+       ORIENT(fp, 1);
+       r = __fputwc(wc, fp, loc);
        FUNLOCKFILE(fp);
 
        return (r);