X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Fvsnprintf.c;h=165ed54ce3a1fb600e317a383c7075edbd955a6f;hb=d1d0e8dbd23a9691841c61c2d30d0ce7343f9adb;hp=84ad51dc462d41a7e14c4b4a747a3ec076e1d2dc;hpb=42e018009a78cdddd97fd18d2b6bb02d8e0fe16e;p=pdclib.old diff --git a/functions/stdio/vsnprintf.c b/functions/stdio/vsnprintf.c index 84ad51d..165ed54 100644 --- a/functions/stdio/vsnprintf.c +++ b/functions/stdio/vsnprintf.c @@ -11,11 +11,21 @@ #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 = { 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.current = 0; + status.s = s; + status.width = 0; + status.prec = 0; + status.stream = NULL; + va_copy( status.arg, arg ); + while ( *format != '\0' ) { const char * rc; @@ -31,6 +41,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; } @@ -39,10 +50,29 @@ int vsnprintf( char * s, size_t n, const char * format, _PDCLIB_va_list arg ) #ifdef TEST #include <_PDCLIB_test.h> +#include +#include +#include + +static int testprintf( char * s, const char * format, ... ) +{ + int i; + va_list arg; + va_start( arg, format ); + i = vsnprintf( s, 100, format, arg ); + va_end( arg ); + return i; +} + +#define TESTCASE_SPRINTF( x ) if ( strcmp( target, x ) == 0 ) {} \ + else { TEST_RESULTS += 1; printf( "FAILED: " __FILE__ ", line %d - \"%s\" != %s\n", __LINE__, target, #x ); } + int main( void ) { - TESTCASE( NO_TESTDRIVER ); + char target[100]; +#include "printf_testcases.incl" return TEST_RESULTS; } #endif +