]> git.saurik.com Git - apple/libc.git/blobdiff - locale/FreeBSD/mbrtowc.c
Libc-1082.50.1.tar.gz
[apple/libc.git] / locale / FreeBSD / mbrtowc.c
index a3b2dd65da53a96e9443e8b574cba600d12fbf0e..023c8b25160d2d6d85e0fae9d4e74978de3a1c33 100644 (file)
@@ -1,5 +1,5 @@
 /*-
- * Copyright (c) 2002 Tim J. Robbins.
+ * Copyright (c) 2002-2004 Tim J. Robbins.
  * All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/locale/mbrtowc.c,v 1.3 2002/11/10 10:49:14 tjr Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/locale/mbrtowc.c,v 1.7 2004/05/12 14:09:04 tjr Exp $");
+
+#include "xlocale_private.h"
 
-#include <errno.h>
-#include <rune.h>
-#include <stdlib.h>
 #include <wchar.h>
+#include "mblocal.h"
 
 size_t
-mbrtowc(wchar_t * __restrict pwc, const char * __restrict s, size_t n,
-    mbstate_t * __restrict ps __unused)
+mbrtowc_l(wchar_t * __restrict pwc, const char * __restrict s,
+    size_t n, mbstate_t * __restrict ps, locale_t loc)
 {
-        const char *e;
-        rune_t r;
-
-       if (s == NULL) {
-               pwc = NULL;
-               s = "";
-               n = 1;
-       }
-
-       if ((r = sgetrune(s, n, &e)) == _INVALID_RUNE) {
-               /*
-                * The design of sgetrune() doesn't give us any way to tell
-                * between incomplete and invalid multibyte sequences.
-                */
-
-               if (n >= (size_t)MB_CUR_MAX) {
-                       /*
-                        * If we have been supplied with at least MB_CUR_MAX
-                        * bytes and still cannot find a valid character, the
-                        * data must be invalid.
-                        */
-                       errno = EILSEQ;
-                       return ((size_t)-1);
-               }
-
-               /*
-                * .. otherwise, it's an incomplete character or an invalid
-                * character we cannot detect yet.
-                */
-               return ((size_t)-2);
-       }
-
-       if (pwc != NULL)
-               *pwc = (wchar_t)r;
+       NORMALIZE_LOCALE(loc);
+       if (ps == NULL)
+               ps = &loc->__mbs_mbrtowc;
+       return (loc->__lc_ctype->__mbrtowc(pwc, s, n, ps, loc));
+}
 
-       return (r != 0 ? (size_t)(e - s) : 0);
+size_t
+mbrtowc(wchar_t * __restrict pwc, const char * __restrict s,
+    size_t n, mbstate_t * __restrict ps)
+{
+       return mbrtowc_l(pwc, s, n, ps, __current_locale());
 }