X-Git-Url: https://pd.if.org/git/?p=pdclib.old;a=blobdiff_plain;f=functions%2Fstdio%2Fvsnprintf.c;h=6cc233d97f4bed54e2cea64b20ac092734f2c163;hp=cda7ab6579d4f45ef9d47580fb5ef540e070d094;hb=3309ec3ad8a5db735eaa2de7f5dc6a331d8e7319;hpb=2d43dbb1c70aee6c3474c254c0a2302ef39c0c7a diff --git a/functions/stdio/vsnprintf.c b/functions/stdio/vsnprintf.c index cda7ab6..6cc233d 100644 --- a/functions/stdio/vsnprintf.c +++ b/functions/stdio/vsnprintf.c @@ -11,50 +11,38 @@ #ifndef REGTEST #include <_PDCLIB_io.h> +#include -int vsnprintf( char * _PDCLIB_restrict s, - size_t n, - const char * _PDCLIB_restrict format, - _PDCLIB_va_list arg ) +struct state { + size_t bufrem; + char *bufp; +}; + +static size_t strout( void *p, const char *buf, size_t sz ) { - /* TODO: This function should interpret format as multibyte characters. */ - struct _PDCLIB_status_t status; - status.base = 0; - status.flags = 0; - status.n = n; - status.i = 0; - status.current = 0; - status.s = s; - status.width = 0; - status.prec = 0; - status.stream = NULL; - va_copy( status.arg, arg ); + struct state *s = p; + size_t copy = s->bufrem >= sz ? sz : s->bufrem; + memcpy( s->bufp, buf, copy ); + s->bufrem -= copy; + s->bufp += copy; + return sz; +} - while ( *format != '\0' ) - { - const char * rc; - if ( ( *format != '%' ) || ( ( rc = _PDCLIB_print( format, &status ) ) == format ) ) - { - /* No conversion specifier, print verbatim */ - if ( status.i < n ) - { - s[ status.i ] = *format; - } - status.i++; - format++; - } - else - { - /* Continue parsing after conversion specifier */ - format = rc; - } - } - if ( status.i < n ) +int vsnprintf( char * _PDCLIB_restrict s, + size_t n, + const char * _PDCLIB_restrict format, + _PDCLIB_va_list arg ) +{ + struct state st; + st.bufrem = n; + st.bufp = s; + int r = _vcbprintf( &st, strout, format, arg ); + if ( st.bufrem ) { - s[ status.i ] = '\0'; + *st.bufp = 0; } - va_end( status.arg ); - return status.i; + + return r; } #endif