]> git.saurik.com Git - apple/libc.git/blobdiff - locale/FreeBSD/mbsrtowcs.c
Libc-1081.1.3.tar.gz
[apple/libc.git] / locale / FreeBSD / mbsrtowcs.c
index afff52f77897fb65e0d32087bdae0e3e5d090326..da8b1e41cbac9bbbc3b9948111caacf36c6bc32c 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/mbsrtowcs.c,v 1.2 2002/09/06 11:23:45 tjr Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/locale/mbsrtowcs.c,v 1.6 2004/07/21 10:54:57 tjr Exp $");
+
+#include "xlocale_private.h"
 
 #include <errno.h>
 #include <limits.h>
 #include <stdlib.h>
 #include <wchar.h>
+#include "mblocal.h"
 
 size_t
-mbsrtowcs(wchar_t * __restrict dst, const char ** __restrict src, size_t len,
-    mbstate_t * __restrict ps __unused)
+mbsrtowcs_l(wchar_t * __restrict dst, const char ** __restrict src, size_t len,
+    mbstate_t * __restrict ps, locale_t loc)
 {
-       const char *s;
-       size_t nchr;
-       wchar_t wc;
-       int nb;
-
-       s = *src;
-       nchr = 0;
-
-       if (dst == NULL) {
-               for (;;) {
-                       if ((nb = (int)mbrtowc(&wc, s, MB_CUR_MAX, NULL)) < 0)
-                               /* Invalid sequence - mbrtowc() sets errno. */
-                               return ((size_t)-1);
-                       else if (nb == 0)
-                               return (nchr);
-                       s += nb;
-                       nchr++;
-               }
-               /*NOTREACHED*/
-       }
+       NORMALIZE_LOCALE(loc);
+       if (ps == NULL)
+               ps = &loc->__mbs_mbsrtowcs;
+       return (loc->__lc_ctype->__mbsnrtowcs(dst, src, SIZE_T_MAX, len, ps, loc));
+}
 
-       while (len-- > 0) {
-               if ((nb = (int)mbrtowc(dst, s, MB_CUR_MAX, NULL)) < 0) {
-                       *src = s;
-                       return ((size_t)-1);
-               } else if (nb == 0) {
-                       *src = NULL;
-                       return (nchr);
-               }
-               s += nb;
-               nchr++;
-               dst++;
-       }
-       *src = s;
-       return (nchr);
+size_t
+mbsrtowcs(wchar_t * __restrict dst, const char ** __restrict src, size_t len,
+    mbstate_t * __restrict ps)
+{
+       return mbsrtowcs_l(dst, src, len, ps, __current_locale());
 }