X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffputs.c;h=fd181cf36f3483121067f31d4726ccf666d4e041;hb=d865c4403fc91d1f1ac95ba76febcee9f429bb97;hp=7a62d03de2ff5178b624c68b5fc0c381c407309a;hpb=393020b6e48719d27699dea6b29e53025bbd5123;p=pdclib diff --git a/functions/stdio/fputs.c b/functions/stdio/fputs.c index 7a62d03..fd181cf 100644 --- a/functions/stdio/fputs.c +++ b/functions/stdio/fputs.c @@ -1,5 +1,3 @@ -/* $Id$ */ - /* fputs( const char *, FILE * ) This file is part of the Public Domain C Library (PDCLib). @@ -9,9 +7,10 @@ #include #ifndef REGTEST -#include <_PDCLIB_glue.h> -int fputs( const char * s, struct _PDCLIB_file_t * stream ) +#include "_PDCLIB_glue.h" + +int fputs( const char * _PDCLIB_restrict s, struct _PDCLIB_file_t * _PDCLIB_restrict stream ) { if ( _PDCLIB_prepwrite( stream ) == EOF ) { @@ -24,9 +23,9 @@ int fputs( const char * s, struct _PDCLIB_file_t * stream ) buffer runs full. */ stream->buffer[ stream->bufidx++ ] = *s; - /* TODO: Should IOLBF flush on \n, or the correct EOL sequence of the system? */ - if ( ( stream->bufidx == stream->bufsize ) - || ( ( stream->status & _IOLBF ) && *s == '\n' ) ) + if ( ( stream->bufidx == stream->bufsize ) || + ( ( stream->status & _IOLBF ) && *s == '\n' ) + ) { if ( _PDCLIB_flushbuffer( stream ) == EOF ) { @@ -46,16 +45,16 @@ int fputs( const char * s, struct _PDCLIB_file_t * stream ) } #endif + #ifdef TEST -#include <_PDCLIB_test.h> + +#include "_PDCLIB_test.h" int main( void ) { - char const * const testfile = "testfile"; 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 ) @@ -63,9 +62,7 @@ int main( void ) TESTCASE( fgetc( fh ) == message[i] ); } TESTCASE( fclose( fh ) == 0 ); - TESTCASE( remove( testfile ) == 0 ); return TEST_RESULTS; } #endif -