summaryrefslogtreecommitdiff
path: root/lib/mlibc/options/ansi/generic/uchar.cpp
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2024-03-07 17:28:00 -0500
committerIan Moffett <ian@osmora.org>2024-03-07 17:28:32 -0500
commitbd5969fc876a10b18613302db7087ef3c40f18e1 (patch)
tree7c2b8619afe902abf99570df2873fbdf40a4d1a1 /lib/mlibc/options/ansi/generic/uchar.cpp
parenta95b38b1b92b172e6cc4e8e56a88a30cc65907b0 (diff)
lib: Add mlibc
Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'lib/mlibc/options/ansi/generic/uchar.cpp')
-rw-r--r--lib/mlibc/options/ansi/generic/uchar.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/lib/mlibc/options/ansi/generic/uchar.cpp b/lib/mlibc/options/ansi/generic/uchar.cpp
new file mode 100644
index 0000000..cb13c12
--- /dev/null
+++ b/lib/mlibc/options/ansi/generic/uchar.cpp
@@ -0,0 +1,23 @@
+#include <bits/ensure.h>
+#include <uchar.h>
+#include <wchar.h>
+
+size_t c32rtomb(char *, char32_t, mbstate_t *) MLIBC_STUB_BODY
+
+size_t mbrtoc32(char32_t *__restrict pc32, const char *__restrict pmb, size_t max, mbstate_t *__restrict ps) {
+ static mbstate_t internal_state;
+
+ if(!ps)
+ ps = &internal_state;
+
+ if(!pmb)
+ return mbrtoc32(0, "", 1, ps);
+
+ wchar_t wc;
+ size_t ret = mbrtowc(&wc, pmb, max, ps);
+
+ if (ret <= 4 && pc32)
+ *pc32 = wc;
+
+ return ret;
+}