summaryrefslogtreecommitdiff
path: root/newlib/libc/stdlib/mbstowcs_r.c
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:38:53 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:39:34 -0500
commitf95a4a932476be2ba99e2fd081e8d2bc6ea12813 (patch)
tree75f67192cb2d7b7b575c94edda318e475239b63c /newlib/libc/stdlib/mbstowcs_r.c
parentf60aca96985e68c7d8a52eb7bc955fb80e132f73 (diff)
Import newlib and create makefile
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 0000000..5478849
--- /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;
+}