X-Git-Url: https://git.gag.com/?p=fw%2Fpdclib;a=blobdiff_plain;f=functions%2Fstdio%2Ffclose.c;h=cfea90234a9e89e5ad76b8d9ee13b72bca750862;hp=0e822eb95ad58af5518497af060b032a22a63d7e;hb=185c9e2dc3a58f33f12d406049b36350c93dc00b;hpb=dde5691676cbf37372640da49733995b314292b7 diff --git a/functions/stdio/fclose.c b/functions/stdio/fclose.c index 0e822eb..cfea902 100644 --- a/functions/stdio/fclose.c +++ b/functions/stdio/fclose.c @@ -49,8 +49,10 @@ 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; @@ -70,23 +72,23 @@ int main( void ) #ifndef REGTEST struct _PDCLIB_file_t * file1; struct _PDCLIB_file_t * file2; - remove( "testfile1" ); - remove( "testfile2" ); + remove( testfile1 ); + remove( testfile2 ); TESTCASE( _PDCLIB_filelist == stdin ); - TESTCASE( ( file1 = fopen( "testfile1", "w" ) ) != NULL ); + TESTCASE( ( file1 = fopen( testfile1, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file1 ); - TESTCASE( ( file2 = fopen( "testfile2", "w" ) ) != NULL ); + TESTCASE( ( file2 = fopen( testfile2, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file2 ) == 0 ); TESTCASE( _PDCLIB_filelist == file1 ); - TESTCASE( ( file2 = fopen( "testfile1", "w" ) ) != NULL ); + TESTCASE( ( file2 = fopen( testfile1, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file1 ) == 0 ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file2 ) == 0 ); TESTCASE( _PDCLIB_filelist == stdin ); - remove( "testfile1" ); - remove( "testfile2" ); + remove( testfile1 ); + remove( testfile2 ); #else puts( " NOTEST fclose() test driver is PDCLib-specific." ); #endif