--- /dev/null
+/* size_t mbrtoc16(\r
+ char16_t *restrict pc16,\r
+ const char *restrict s, \r
+ size_t n,\r
+ mbstate_t *restrict ps);\r
+\r
+ This file is part of the Public Domain C Library (PDCLib).\r
+ Permission is granted to use, modify, and / or redistribute at will.\r
+*/\r
+\r
+#ifndef REGTEST\r
+#include <uchar.h>\r
+#include <errno.h>\r
+#include <stdint.h>\r
+#include <assert.h>\r
+#include <_PDCLIB_encoding.h>\r
+#include <_PDCLIB_locale.h>\r
+\r
+size_t mbrtoc16_l(\r
+ char16_t *restrict pc16,\r
+ const char *restrict s, \r
+ size_t n,\r
+ mbstate_t *restrict ps,\r
+ locale_t restrict l\r
+)\r
+{\r
+ size_t dstlen = 1;\r
+ size_t nr = n;\r
+\r
+ if(!l->_Codec->__mbstoc16s) {\r
+ // No UTF-16 support in codec. Must synthesize on top of UCS-4 support.\r
+\r
+ if(ps->_Surrogate) {\r
+ // If a pending surrogate is stored in the state\r
+ *pc16 = ps->_Surrogate;\r
+ ps->_Surrogate = 0;\r
+ return (size_t) -3;\r
+ }\r
+\r
+ char32_t c32;\r
+ size_t res = mbrtoc32_l(&c32, s, n, ps, l);\r
+ if(res != (size_t) -1) {\r
+ // Conversion was successful. Check for surrogates\r
+ if(c32 <= 0xFFFF) {\r
+ // BMP char\r
+ *pc16 = c32;\r
+ } else {\r
+ // Supplementary char\r
+ *pc16 = 0xD800 | (c32 >> 10);\r
+ ps->_Surrogate = 0xDC00 | (c32 & 0x3FF);\r
+ }\r
+ }\r
+ return res;\r
+ } else if(l->_Codec->__mbstoc16s(&pc16, &dstlen, &s, &nr, ps)) {\r
+ // Successful conversion\r
+ if(dstlen == 0) {\r
+ // A character was output\r
+ if(nr == n) {\r
+ // The output character resulted entirely from stored state\r
+ return (size_t) -3;\r
+ } else if(pc16[-1] == 0) {\r
+ // Was null character\r
+ return 0;\r
+ } else {\r
+ // Count of processed characters\r
+ return n - nr;\r
+ }\r
+ } else {\r
+ assert(nr == 0 && "Must have processed whole input");\r
+ return (size_t) -2;\r
+ }\r
+ } else {\r
+ // Failed conversion\r
+ errno = EILSEQ;\r
+ return (size_t) -1;\r
+ }\r
+}\r
+\r
+size_t mbrtoc16(\r
+ char16_t *restrict pc16,\r
+ const char *restrict s, \r
+ size_t n,\r
+ mbstate_t *restrict ps\r
+)\r
+{\r
+ return mbrtoc16_l(pc16, s, n, ps, _PDCLIB_threadlocale());\r
+}\r
+\r
+#endif\r
+\r
+#ifdef TEST\r
+#include <_PDCLIB_test.h>\r
+\r
+int main( void )\r
+{\r
+ TESTCASE( NO_TESTDRIVER );\r
+ return TEST_RESULTS;\r
+}\r
+#endif\r