X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffclose.c;h=b42cab3b14182f482afd1ad1c797437ba3fcacb1;hb=2b10f10cde517fede45e620a0c3a7948d90afd7b;hp=c33860a11ce87741125834bfa5f45ee74fc2896e;hpb=b1fc26afebd4d557ff89a44bc21767a8704c3809;p=pdclib diff --git a/functions/stdio/fclose.c b/functions/stdio/fclose.c index c33860a..b42cab3 100644 --- a/functions/stdio/fclose.c +++ b/functions/stdio/fclose.c @@ -8,7 +8,8 @@ #include #ifndef REGTEST -#include <_PDCLIB_glue.h> + +#include "_PDCLIB_glue.h" extern struct _PDCLIB_file_t * _PDCLIB_filelist; @@ -46,6 +47,11 @@ int fclose( struct _PDCLIB_file_t * stream ) { remove( stream->filename ); } + /* Free user buffer (SetVBuf allocated) */ + if ( stream->status & _PDCLIB_FREEBUFFER ) + { + free( stream->buffer ); + } /* Free stream */ if ( ! ( stream->status & _PDCLIB_STATIC ) ) { @@ -66,7 +72,8 @@ int fclose( struct _PDCLIB_file_t * stream ) #endif #ifdef TEST -#include <_PDCLIB_test.h> + +#include "_PDCLIB_test.h" int main( void ) { @@ -82,7 +89,7 @@ int main( void ) TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file2 ) == 0 ); TESTCASE( _PDCLIB_filelist == file1 ); - TESTCASE( ( file2 = fopen( testfile1, "w" ) ) != NULL ); + TESTCASE( ( file2 = fopen( testfile2, "w" ) ) != NULL ); TESTCASE( _PDCLIB_filelist == file2 ); TESTCASE( fclose( file1 ) == 0 ); TESTCASE( _PDCLIB_filelist == file2 ); @@ -97,4 +104,3 @@ int main( void ) } #endif -