X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Fputs.c;h=35daf64a85a39bb67f3a346122bce1b2d8566bfe;hb=3309ec3ad8a5db735eaa2de7f5dc6a331d8e7319;hp=b7954ea0c69b92895a76741d8df170c6ccdd4cab;hpb=d17bd723e4bb49882b01c1883df0ccae6f315cf3;p=pdclib.old diff --git a/functions/stdio/puts.c b/functions/stdio/puts.c index b7954ea..35daf64 100644 --- a/functions/stdio/puts.c +++ b/functions/stdio/puts.c @@ -9,11 +9,11 @@ #include #ifndef REGTEST -#include <_PDCLIB_glue.h> +#include <_PDCLIB_io.h> extern char * _PDCLIB_eol; -int puts( const char * s ) +int _PDCLIB_puts_unlocked( const char * s ) { if ( _PDCLIB_prepwrite( stdout ) == EOF ) { @@ -42,6 +42,14 @@ int puts( const char * s ) } } +int puts( const char * s ) +{ + _PDCLIB_flockfile( stdout ); + int r = _PDCLIB_puts_unlocked( s ); + _PDCLIB_funlockfile( stdout ); + return r; +} + #endif #ifdef TEST @@ -49,7 +57,18 @@ int puts( const char * s ) int main( void ) { - TESTCASE( puts( "SUCCESS testing puts()" ) >= 0 ); + FILE * fh; + char const * message = "SUCCESS testing puts()"; + char buffer[23]; + buffer[22] = 'x'; + TESTCASE( ( fh = freopen( testfile, "wb+", stdout ) ) != NULL ); + TESTCASE( puts( message ) >= 0 ); + rewind( fh ); + TESTCASE( fread( buffer, 1, 22, fh ) == 22 ); + TESTCASE( memcmp( buffer, message, 22 ) == 0 ); + TESTCASE( buffer[22] == 'x' ); + TESTCASE( fclose( fh ) == 0 ); + TESTCASE( remove( testfile ) == 0 ); return TEST_RESULTS; }