Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2000-02-17 22:39:52 +0300
committerChristopher Faylor <me@cgf.cx>2000-02-17 22:39:52 +0300
commit8a0efa53e44919bcf5ccb1d3353618a82afdf8bc (patch)
tree68c3dbf3f2c6fd5d49777def9914d77b5cd4589d /newlib/libc/stdlib/mbstowcs_r.c
parent1fd5e000ace55b323124c7e556a7a864b972a5c4 (diff)
import newlib-2000-02-17 snapshot
Diffstat (limited to 'newlib/libc/stdlib/mbstowcs_r.c')
-rw-r--r--newlib/libc/stdlib/mbstowcs_r.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/newlib/libc/stdlib/mbstowcs_r.c b/newlib/libc/stdlib/mbstowcs_r.c
new file mode 100644
index 000000000..5478849bb
--- /dev/null
+++ b/newlib/libc/stdlib/mbstowcs_r.c
@@ -0,0 +1,29 @@
+#include <stdlib.h>
+
+size_t
+_DEFUN (_mbstowcs_r, (reent, pwcs, s, n, state),
+ struct _reent *r _AND
+ wchar_t *pwcs _AND
+ const char *s _AND
+ size_t n _AND
+ int *state)
+{
+ wchar_t *ptr = pwcs;
+ size_t max = n;
+ char *t = (char *)s;
+ int bytes;
+
+ while (n > 0)
+ {
+ bytes = _mbtowc_r (r, ptr, t, MB_CUR_MAX, state);
+ if (bytes == -1)
+ return -1;
+ else if (bytes == 0)
+ return ptr - pwcs;
+ t += bytes;
+ ++ptr;
+ --n;
+ }
+
+ return max;
+}