X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffclose.c;h=3d9e25724f45bdf58de3ee14ba16d183af0bb0fa;hb=59953f20c461a26fd6f0be8c28c784709da51a5e;hp=cfea90234a9e89e5ad76b8d9ee13b72bca750862;hpb=0326491c5ed243ea6efc5e66e3a6ea21427aad92;p=pdclib diff --git a/functions/stdio/fclose.c b/functions/stdio/fclose.c index cfea902..3d9e257 100644 --- a/functions/stdio/fclose.c +++ b/functions/stdio/fclose.c @@ -8,9 +8,11 @@ #include #include +#include #ifndef REGTEST #include <_PDCLIB_glue.h> +#include extern struct _PDCLIB_file_t * _PDCLIB_filelist; @@ -32,8 +34,13 @@ int fclose( struct _PDCLIB_file_t * stream ) return EOF; } } + + /* Release mutex*/ + mtx_destroy( &stream->lock ); + /* Close handle */ - _PDCLIB_close( stream->handle ); + stream->ops->close(stream->handle); + /* Remove stream from list */ if ( previous != NULL ) { @@ -58,7 +65,8 @@ int fclose( struct _PDCLIB_file_t * stream ) previous = current; current = current->next; } - _PDCLIB_errno = _PDCLIB_EIO; + + errno = EINVAL; return -1; } @@ -81,14 +89,14 @@ 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 ); TESTCASE( fclose( file2 ) == 0 ); TESTCASE( _PDCLIB_filelist == stdin ); - remove( testfile1 ); - remove( testfile2 ); + TESTCASE( remove( testfile1 ) == 0 ); + TESTCASE( remove( testfile2 ) == 0 ); #else puts( " NOTEST fclose() test driver is PDCLib-specific." ); #endif