X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Fvsnprintf.c;h=fd29580db984b072ed1d80b699b51b97d452f167;hb=0e35e82c5e9a0804864839e8fc0e985b1ae41f07;hp=9e54dca1bb392076e07c0566fa6449403b24b90b;hpb=35ae2c90b1e06be0b78a67a11c1f14c71f547a40;p=pdclib.old diff --git a/functions/stdio/vsnprintf.c b/functions/stdio/vsnprintf.c index 9e54dca..fd29580 100644 --- a/functions/stdio/vsnprintf.c +++ b/functions/stdio/vsnprintf.c @@ -10,8 +10,12 @@ #include #ifndef REGTEST +#include <_PDCLIB_io.h> -int vsnprintf( char * _PDCLIB_restrict s, size_t n, const char * _PDCLIB_restrict 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. */ struct _PDCLIB_status_t status; @@ -32,7 +36,12 @@ int vsnprintf( char * _PDCLIB_restrict s, size_t n, const char * _PDCLIB_restric if ( ( *format != '%' ) || ( ( rc = _PDCLIB_print( format, &status ) ) == format ) ) { /* No conversion specifier, print verbatim */ - s[ status.i++ ] = *(format++); + if ( status.i < n ) + { + s[ status.i ] = *format; + } + status.i++; + format++; } else { @@ -40,7 +49,10 @@ int vsnprintf( char * _PDCLIB_restrict s, size_t n, const char * _PDCLIB_restric format = rc; } } - s[ status.i ] = '\0'; + if ( status.i < n ) + { + s[ status.i ] = '\0'; + } va_end( status.arg ); return status.i; } @@ -49,11 +61,9 @@ int vsnprintf( char * _PDCLIB_restrict s, size_t n, const char * _PDCLIB_restric #ifdef TEST #define _PDCLIB_FILEID "stdio/vsnprintf.c" -#include <_PDCLIB_test.h> +#define _PDCLIB_STRINGIO -#include -#include -#include +#include <_PDCLIB_test.h> static int testprintf( char * s, const char * format, ... ) { @@ -68,7 +78,7 @@ static int testprintf( char * s, const char * format, ... ) int main( void ) { char target[100]; -#include "printf_testcases.incl" +#include "printf_testcases.h" return TEST_RESULTS; }