X-Git-Url: https://pd.if.org/git/?p=pdclib.old;a=blobdiff_plain;f=functions%2Fstdio%2Fvsnprintf.c;fp=functions%2Fstdio%2Fvsnprintf.c;h=9c9ab591f0993c2f5e78a2278fc8e283e56c9427;hp=96a151bb2ae3a53e48f5bbc963a8308e635f05f7;hb=0d54a75af25ca44411e7c4190cc2a93a390e61a2;hpb=18af9d0a4cd252433e0cbd5daf4640e325c9d0ab diff --git a/functions/stdio/vsnprintf.c b/functions/stdio/vsnprintf.c index 96a151b..9c9ab59 100644 --- a/functions/stdio/vsnprintf.c +++ b/functions/stdio/vsnprintf.c @@ -15,7 +15,18 @@ int vsnprintf( char * s, size_t n, const char * 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 = { 0, 0, n, 0, 0, s, 0, 0, NULL, 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; + va_copy( status.arg, arg ); + // = { 0, 0, n, 0, 0, s, 0, 0, NULL }; while ( *format != '\0' ) { const char * rc; @@ -31,6 +42,7 @@ int vsnprintf( char * s, size_t n, const char * format, _PDCLIB_va_list arg ) } } s[ status.i ] = '\0'; + va_end( status.arg ); return status.i; } @@ -313,3 +325,4 @@ int main( void ) } #endif +