diff options
| author | Jakob Kaivo <jkk@ung.org> | 2024-06-05 14:35:40 -0400 |
|---|---|---|
| committer | Jakob Kaivo <jkk@ung.org> | 2024-06-05 14:35:40 -0400 |
| commit | d105976002aa32a3cbe42b7f06a0dcba5d176afd (patch) | |
| tree | ccd57fa63807cb15cc08eb43231b15b60c660d5f /src/wchar/mbrtowc.c | |
| parent | 9252dc08f0a9ac7507b28e55b8ae7e4df605c79d (diff) | |
implement tracking mechanisms for mbstate_t
Diffstat (limited to 'src/wchar/mbrtowc.c')
| -rw-r--r-- | src/wchar/mbrtowc.c | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/src/wchar/mbrtowc.c b/src/wchar/mbrtowc.c index 16e2a937..aa7c4803 100644 --- a/src/wchar/mbrtowc.c +++ b/src/wchar/mbrtowc.c @@ -1,27 +1,29 @@ -#if 0 - #include <wchar.h> +#include "_wchar.h" +GCC_SSE_HACK size_t mbrtowc(wchar_t * restrict pwc, const char * restrict s, size_t n, mbstate_t * restrict ps) { + static struct __mbstate_t internal = { 0 }; + static mbstate_t ip = { &internal }; + + if (ps == NULL) { + ps = &ip; + } + SIGNAL_SAFE(0); + ASSERT_MBSTATE(ps, MBTOW, s, pwc); /* TODO: overlap */ - (void)ps; (void)pwc; (void)n; - if (s == NULL) { - s = ""; - n = 1; + return mbrtowc(NULL, "", 1, ps); } - /* TODO */ + SET_MBSTATE(ps, MBTOW, s, pwc); - return 0; + return n; } /* STDC(199409) */ - - -#endif |
