X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffclose.c;h=d20cb3e90a95a5c5d82b4967ff383fff9e95b7ca;hb=4955ba67ce17eb49d6ac19668d140ade0b501b06;hp=2b686946c2f55ed9f5d594cec18b579dbccfb7a9;hpb=015e9131c3aa3f39b34612d0d2fce242f6deb7b4;p=pdclib.old diff --git a/functions/stdio/fclose.c b/functions/stdio/fclose.c index 2b68694..d20cb3e 100644 --- a/functions/stdio/fclose.c +++ b/functions/stdio/fclose.c @@ -8,6 +8,7 @@ #include #include +#include #ifndef REGTEST #include <_PDCLIB_glue.h> @@ -49,14 +50,17 @@ int fclose( struct _PDCLIB_file_t * stream ) remove( stream->filename ); } /* Free stream */ - free( stream ); - + if ( ! ( stream->status & _PDCLIB_STATIC ) ) + { + free( stream ); + } return 0; } previous = current; current = current->next; } - _PDCLIB_errno = _PDCLIB_EIO; + + errno = EINVAL; return -1; } @@ -70,23 +74,23 @@ int main( void ) #ifndef REGTEST struct _PDCLIB_file_t * file1; struct _PDCLIB_file_t * file2; - remove( "testing/testfile1" ); - remove( "testing/testfile2" ); + remove( testfile1 ); + remove( testfile2 ); TESTCASE( _PDCLIB_filelist == stdin ); - TESTCASE( ( file1 = fopen( "testing/testfile1", "w" ) ) != NULL ); + TESTCASE( ( file1 = fopen( testfile1, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file1 ); - TESTCASE( ( file2 = fopen( "testing/testfile2", "w" ) ) != NULL ); + TESTCASE( ( file2 = fopen( testfile2, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file2 ) == 0 ); TESTCASE( _PDCLIB_filelist == file1 ); - TESTCASE( ( file2 = fopen( "testing/testfile1", "w" ) ) != NULL ); + TESTCASE( ( file2 = fopen( testfile2, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file1 ) == 0 ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file2 ) == 0 ); TESTCASE( _PDCLIB_filelist == stdin ); - remove( "testing/testfile1" ); - remove( "testing/testfile2" ); + TESTCASE( remove( testfile1 ) == 0 ); + TESTCASE( remove( testfile2 ) == 0 ); #else puts( " NOTEST fclose() test driver is PDCLib-specific." ); #endif