X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffseek.c;h=72fe951d22d0f917f53849275349d3cb61f50aa1;hb=e1c526e9bad3f6e69391e94059096145390508d3;hp=18c38c324ecc7dbacaa8fe734550360f28a4f0f9;hpb=852ad49d5888724e4e4f82a6d51d13b0e8029e28;p=pdclib diff --git a/functions/stdio/fseek.c b/functions/stdio/fseek.c index 18c38c3..72fe951 100644 --- a/functions/stdio/fseek.c +++ b/functions/stdio/fseek.c @@ -1,5 +1,3 @@ -/* $Id$ */ - /* fseek( FILE *, long offset, int ) This file is part of the Public Domain C Library (PDCLib). @@ -9,10 +7,9 @@ #include #ifndef REGTEST +#include <_PDCLIB_io.h> -#include <_PDCLIB_glue.h> - -int fseek( struct _PDCLIB_file_t * stream, long loffset, int whence ) +int _PDCLIB_fseek_unlocked( FILE * stream, long loffset, int whence ) { _PDCLIB_int64_t offset = loffset; if ( stream->status & _PDCLIB_FWRITE ) @@ -31,12 +28,20 @@ int fseek( struct _PDCLIB_file_t * stream, long loffset, int whence ) if ( whence == SEEK_CUR ) { whence = SEEK_SET; - offset += stream->pos.offset; + offset += _PDCLIB_ftell64_unlocked( stream ); } return ( _PDCLIB_seek( stream, offset, whence ) != EOF ) ? 0 : EOF; } +int fseek( FILE * stream, long loffset, int whence ) +{ + _PDCLIB_flockfile( stream ); + int r = _PDCLIB_fseek_unlocked( stream, loffset, whence ); + _PDCLIB_funlockfile( stream ); + return r; +} + #endif #ifdef TEST @@ -83,6 +88,16 @@ int main( void ) TESTCASE( ftell( fh ) == 2 ); TESTCASE( fseek( fh, 2, SEEK_SET ) == 0 ); TESTCASE( fgetc( fh ) == teststring[2] ); + /* PDCLIB-7: Check that we handle the underlying file descriptor correctly + * in the SEEK_CUR case */ + TESTCASE( fseek( fh, 10, SEEK_SET ) == 0 ); + TESTCASE( ftell( fh ) == 10l ); + TESTCASE( fseek( fh, 0, SEEK_CUR ) == 0 ); + TESTCASE( ftell( fh ) == 10l ); + TESTCASE( fseek( fh, 2, SEEK_CUR ) == 0 ); + TESTCASE( ftell( fh ) == 12l ); + TESTCASE( fseek( fh, -1, SEEK_CUR ) == 0 ); + TESTCASE( ftell( fh ) == 11l ); /* Checking error handling */ TESTCASE( fseek( fh, -5, SEEK_SET ) == -1 ); TESTCASE( fseek( fh, 0, SEEK_END ) == 0 );