X-Git-Url: https://pd.if.org/git/?p=pdclib;a=blobdiff_plain;f=functions%2Fstdio%2Fclearerr.c;h=922f6ab9d239e18cbf5eea9d959d0102c10d9f54;hp=2bfe7c508448eb92830605de1f78031825ef16d2;hb=393020b6e48719d27699dea6b29e53025bbd5123;hpb=f408c1fd633015089d2a0fc6bc31c9f61eeae0a9 diff --git a/functions/stdio/clearerr.c b/functions/stdio/clearerr.c index 2bfe7c5..922f6ab 100644 --- a/functions/stdio/clearerr.c +++ b/functions/stdio/clearerr.c @@ -22,37 +22,33 @@ void clearerr( struct _PDCLIB_file_t * stream ) int main( void ) { -#ifndef REGTEST - FILE file = { 0, { 0, 0 }, NULL, 0, 0, 0, _IONBF, NULL, NULL }; - FILE * fh = &file; + FILE * fh; + remove( "testfile" ); + TESTCASE( ( fh = fopen( "testfile", "w+" ) ) != NULL ); + /* Flags should be clear */ TESTCASE( ! ferror( fh ) ); TESTCASE( ! feof( fh ) ); - fh->status |= _PDCLIB_ERRORFLAG; + /* Reading from input stream - should provoke error */ + TESTCASE( fgetc( fh ) == EOF ); TESTCASE( ferror( fh ) ); TESTCASE( ! feof( fh ) ); + /* clearerr() should clear flags */ clearerr( fh ); TESTCASE( ! ferror( fh ) ); TESTCASE( ! feof( fh ) ); - fh->status |= _PDCLIB_EOFFLAG; - TESTCASE( ! ferror( fh ) ); - TESTCASE( feof( fh ) ); - clearerr( fh ); + /* Reading from empty stream - should provoke EOF */ + rewind( fh ); + TESTCASE( fgetc( fh ) == EOF ); TESTCASE( ! ferror( fh ) ); - TESTCASE( ! feof( fh ) ); - fh->status |= _PDCLIB_EOFFLAG | _PDCLIB_ERRORFLAG; - TESTCASE( ferror( fh ) ); TESTCASE( feof( fh ) ); + /* clearerr() should clear flags */ clearerr( fh ); TESTCASE( ! ferror( fh ) ); TESTCASE( ! feof( fh ) ); -#else - /* TODO: The above is ad-hoc and PDCLib specific. A better test driver - should be internals-agnostic (provoking the error / eof flag by - "regular" operations). - */ - TESTCASE( NO_TESTDRIVER ); -#endif + TESTCASE( fclose( fh ) == 0 ); + remove( "testfile" ); return TEST_RESULTS; } #endif +