X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fmultibyte%2Fmbrtowc.c;h=c94819e720aac361c70bb61e409ac217b303fdf9;hb=2e5fff43dd7fc808197744c67cca7908ac19bb4f;hp=ec32385921cae2a998689355093b38c2a35ed354;hpb=a49e038bab7b3927b6a9c7d0c52f9e1a9cb82629;p=musl diff --git a/src/multibyte/mbrtowc.c b/src/multibyte/mbrtowc.c index ec323859..c94819e7 100644 --- a/src/multibyte/mbrtowc.c +++ b/src/multibyte/mbrtowc.c @@ -1,14 +1,6 @@ -/* - * This code was written by Rich Felker in 2010; no copyright is claimed. - * This code is in the public domain. Attribution is appreciated but - * unnecessary. - */ - #include -#include #include #include - #include "internal.h" size_t mbrtowc(wchar_t *restrict wc, const char *restrict src, size_t n, mbstate_t *restrict st) @@ -17,6 +9,7 @@ size_t mbrtowc(wchar_t *restrict wc, const char *restrict src, size_t n, mbstate unsigned c; const unsigned char *s = (const void *)src; const unsigned N = n; + wchar_t dummy; if (!st) st = (void *)&internal_state; c = *(unsigned *)st; @@ -24,11 +17,12 @@ size_t mbrtowc(wchar_t *restrict wc, const char *restrict src, size_t n, mbstate if (!s) { if (c) goto ilseq; return 0; - } else if (!wc) wc = (void *)&wc; + } else if (!wc) wc = &dummy; if (!n) return -2; if (!c) { if (*s < 0x80) return !!(*wc = *s); + if (MB_CUR_MAX==1) return (*wc = CODEUNIT(*s)), 1; if (*s-SA > SB-SA) goto ilseq; c = bittab[*s++-SA]; n--; } @@ -51,7 +45,7 @@ loop: *(unsigned *)st = c; return -2; ilseq: - *(unsigned *)st = FAILSTATE; + *(unsigned *)st = 0; errno = EILSEQ; return -1; }