X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Fvsnprintf.c;h=dee30dcea6f5e7b202fea93494d580d0de7da11b;hb=268c42b566c2be8deaf4c9c8571d3d2e23bae92d;hp=9c9ab591f0993c2f5e78a2278fc8e283e56c9427;hpb=393020b6e48719d27699dea6b29e53025bbd5123;p=pdclib diff --git a/functions/stdio/vsnprintf.c b/functions/stdio/vsnprintf.c index 9c9ab59..dee30dc 100644 --- a/functions/stdio/vsnprintf.c +++ b/functions/stdio/vsnprintf.c @@ -11,22 +11,12 @@ #ifndef REGTEST -int vsnprintf( char * s, size_t n, const char * format, _PDCLIB_va_list arg ) +int vsnprintf( char * _PDCLIB_restrict s, size_t n, const char * _PDCLIB_restrict format, _PDCLIB_va_list arg ) { - /* TODO: This function should interpret format as multibyte characters. */ - /* Members: base, flags, n, i, this, s, width, prec, stream, arg */ - struct _PDCLIB_status_t status; - status.base = 0; - status.flags = 0; - status.n = n; - status.i = 0; - status.this = 0; - status.s = s; - status.width = 0; - status.prec = 0; - status.stream = NULL; + /* base, flags, n, i, current, s, width, prec, stream, arg */ + struct _PDCLIB_status_t status = { 0, 0, n, 0, 0, s, 0, 0, NULL, NULL }; va_copy( status.arg, arg ); - // = { 0, 0, n, 0, 0, s, 0, 0, NULL }; + while ( *format != '\0' ) { const char * rc;