X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=opt%2Fbasecodecs%2F_PDCLIB_ascii.c;h=7c73d1baf613dc9d8a15511831ff613e014a2c6c;hb=3862b03514c94f37966f61693619e6483ead6045;hp=a705a7a75b43da5b18e429b681601b0ad7d144dc;hpb=4fe88a1c445105a96d08b808831d6fc7480a211d;p=pdclib.old diff --git a/opt/basecodecs/_PDCLIB_ascii.c b/opt/basecodecs/_PDCLIB_ascii.c index a705a7a..7c73d1b 100644 --- a/opt/basecodecs/_PDCLIB_ascii.c +++ b/opt/basecodecs/_PDCLIB_ascii.c @@ -7,13 +7,17 @@ #include #ifndef REGTEST #include +#include <_PDCLIB_encoding.h> + +static bool ascii_mbsinit( const mbstate_t *ps ) +{ return 1; } static bool asciitoc32( - char32_t **restrict p_outbuf, - size_t *restrict p_outsz, - const char **restrict p_inbuf, - size_t *restrict p_insz, - mbstate_t *restrict p_ps + char32_t *restrict *restrict p_outbuf, + size_t *restrict p_outsz, + const char *restrict *restrict p_inbuf, + size_t *restrict p_insz, + mbstate_t *restrict p_ps ) { while(*p_outsz && *p_insz) { @@ -34,11 +38,11 @@ static bool asciitoc32( } static bool c32toascii( - char **restrict p_outbuf, - size_t *restrict p_outsz, - const char32_t **restrict p_inbuf, - size_t *restrict p_insz, - mbstate_t *restrict p_ps + char *restrict *restrict p_outbuf, + size_t *restrict p_outsz, + const char32_t *restrict *restrict p_inbuf, + size_t *restrict p_insz, + mbstate_t *restrict p_ps ) { while(*p_outsz && *p_insz) { @@ -58,9 +62,11 @@ static bool c32toascii( return true; } -_PDCLIB_charcodec _PDCLIB_ascii_codec = { +const struct _PDCLIB_charcodec _PDCLIB_ascii_codec = { + .__mbsinit = ascii_mbsinit, .__mbstoc32s = asciitoc32, .__c32stombs = c32toascii, + .__mb_max = 1, }; #endif