X-Git-Url: https://pd.if.org/git/?p=pdclib.old;a=blobdiff_plain;f=functions%2Fstdio%2Ffclose.c;h=37349c06881b98291e8a824c30b6d3c808ba3c2a;hp=dbd7f6eebbf12199ea8d7a80bbaf566f11035115;hb=35d48051496adf237dcd22ff1324e93b6f351284;hpb=fce9a8538009ea5c113b03c608cedf036ce4a364 diff --git a/functions/stdio/fclose.c b/functions/stdio/fclose.c index dbd7f6e..37349c0 100644 --- a/functions/stdio/fclose.c +++ b/functions/stdio/fclose.c @@ -11,14 +11,15 @@ #include #ifndef REGTEST -#include <_PDCLIB_glue.h> +#include <_PDCLIB_io.h> +#include -extern struct _PDCLIB_file_t * _PDCLIB_filelist; +extern FILE * _PDCLIB_filelist; -int fclose( struct _PDCLIB_file_t * stream ) +int fclose( FILE * stream ) { - struct _PDCLIB_file_t * current = _PDCLIB_filelist; - struct _PDCLIB_file_t * previous = NULL; + FILE * current = _PDCLIB_filelist; + FILE * previous = NULL; /* Checking that the FILE handle is actually one we had opened before. */ while ( current != NULL ) { @@ -38,7 +39,7 @@ int fclose( struct _PDCLIB_file_t * stream ) mtx_destroy( &stream->lock ); /* Close handle */ - _PDCLIB_close( stream->handle ); + stream->ops->close(stream->handle); /* Remove stream from list */ if ( previous != NULL ) @@ -54,6 +55,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 ) ) { @@ -77,8 +83,8 @@ int fclose( struct _PDCLIB_file_t * stream ) int main( void ) { #ifndef REGTEST - struct _PDCLIB_file_t * file1; - struct _PDCLIB_file_t * file2; + FILE * file1; + FILE * file2; remove( testfile1 ); remove( testfile2 ); TESTCASE( _PDCLIB_filelist == stdin );