X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffputs.c;h=0b1e3256f3d32153d88e7e18270b3ad942590fb5;hb=84d648157e22cecc65902ecfdd4e3a1b88d5e53f;hp=1df0ebfa465cab4e81be1983fad5bdc5fe38ca56;hpb=015e9131c3aa3f39b34612d0d2fce242f6deb7b4;p=pdclib.old diff --git a/functions/stdio/fputs.c b/functions/stdio/fputs.c index 1df0ebf..0b1e325 100644 --- a/functions/stdio/fputs.c +++ b/functions/stdio/fputs.c @@ -11,7 +11,8 @@ #ifndef REGTEST #include <_PDCLIB_glue.h> -int fputs( const char * _PDCLIB_restrict s, struct _PDCLIB_file_t * _PDCLIB_restrict stream ) +int fputs_unlocked( const char * _PDCLIB_restrict s, + struct _PDCLIB_file_t * _PDCLIB_restrict stream ) { if ( _PDCLIB_prepwrite( stream ) == EOF ) { @@ -45,6 +46,15 @@ int fputs( const char * _PDCLIB_restrict s, struct _PDCLIB_file_t * _PDCLIB_rest return 0; } +int fputs( const char * _PDCLIB_restrict s, + struct _PDCLIB_file_t * _PDCLIB_restrict stream ) +{ + flockfile( stream ); + int r = fputs_unlocked( s, stream ); + funlockfile( stream ); + return r; +} + #endif #ifdef TEST #include <_PDCLIB_test.h> @@ -53,8 +63,7 @@ int main( void ) { char const * const message = "SUCCESS testing fputs()"; FILE * fh; - remove( testfile ); - TESTCASE( ( fh = fopen( testfile, "w+" ) ) != NULL ); + TESTCASE( ( fh = tmpfile() ) != NULL ); TESTCASE( fputs( message, fh ) >= 0 ); rewind( fh ); for ( size_t i = 0; i < 23; ++i ) @@ -62,7 +71,6 @@ int main( void ) TESTCASE( fgetc( fh ) == message[i] ); } TESTCASE( fclose( fh ) == 0 ); - TESTCASE( remove( testfile ) == 0 ); return TEST_RESULTS; }