about summary refs log tree commit diff
path: root/manual/examples
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2018-04-05 12:50:58 +0200
committerFlorian Weimer <fweimer@redhat.com>2018-04-05 12:50:58 +0200
commit0f339252697e6dcfc9e00be6cd8272d4260b90d2 (patch)
tree144326a4f739b40245b99d80d7f33436e8bbc74c /manual/examples
parent08e92e2443a6ca4cfd45b87e22bef3454f369752 (diff)
downloadglibc-0f339252697e6dcfc9e00be6cd8272d4260b90d2.tar.gz
glibc-0f339252697e6dcfc9e00be6cd8272d4260b90d2.tar.xz
glibc-0f339252697e6dcfc9e00be6cd8272d4260b90d2.zip
manual: Move mbstouwcs to an example C file
Diffstat (limited to 'manual/examples')
-rw-r--r--manual/examples/mbstouwcs.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/manual/examples/mbstouwcs.c b/manual/examples/mbstouwcs.c
new file mode 100644
index 0000000000..5d223da2ae
--- /dev/null
+++ b/manual/examples/mbstouwcs.c
@@ -0,0 +1,28 @@
+#include <stdlib.h>
+#include <string.h>
+#include <wchar.h>
+
+/* Do not include the above headers in the example.
+*/
+wchar_t *
+mbstouwcs (const char *s)
+{
+  size_t len = strlen (s);
+  wchar_t *result = malloc ((len + 1) * sizeof (wchar_t));
+  wchar_t *wcp = result;
+  wchar_t tmp[1];
+  mbstate_t state;
+  size_t nbytes;
+
+  memset (&state, '\0', sizeof (state));
+  while ((nbytes = mbrtowc (tmp, s, len, &state)) > 0)
+    {
+      if (nbytes >= (size_t) -2)
+        /* Invalid input string.  */
+        return NULL;
+      *wcp++ = towupper (tmp[0]);
+      len -= nbytes;
+      s += nbytes;
+    }
+  return result;
+}