]> pd.if.org Git - pdclib.old/blobdiff - functions/stdio/fsetpos.c
[gandr] s/__lp64__/__LP64__/ to match GCC define
[pdclib.old] / functions / stdio / fsetpos.c
index 76c5ede87ec7dea39ef49b194581bfd7a130c878..5a78706731d7f8ee355fdf2e0a4acc55da34bdbf 100644 (file)
@@ -9,17 +9,36 @@
 #include <stdio.h>
 
 #ifndef REGTEST
+#include <_PDCLIB_io.h>
 
-int fsetpos( struct _PDCLIB_file_t * stream, const _PDCLIB_fpos_t * pos )
+int _PDCLIB_fsetpos_unlocked( FILE * stream, 
+                      const _PDCLIB_fpos_t * pos )
 {
-    if ( stream->status & _PDCLIB_WROTELAST )
+    if ( stream->status & _PDCLIB_FWRITE )
     {
-        fflush( stream );
+        if ( _PDCLIB_flushbuffer( stream ) == EOF )
+        {
+            return EOF;
+        }
     }
-    /* TODO: Implement. */
+    if ( _PDCLIB_seek( stream, pos->offset, SEEK_SET ) == EOF )
+    {
+        return EOF;
+    }
+    stream->pos.mbs = pos->mbs;
+    
     return 0;
 }
 
+int fsetpos( FILE * stream, 
+             const _PDCLIB_fpos_t * pos )
+{
+    _PDCLIB_flockfile( stream );
+    int res = _PDCLIB_fsetpos_unlocked( stream, pos );
+    _PDCLIB_funlockfile( stream );
+    return res;
+}
+
 #endif
 
 #ifdef TEST
@@ -27,7 +46,7 @@ int fsetpos( struct _PDCLIB_file_t * stream, const _PDCLIB_fpos_t * pos )
 
 int main( void )
 {
-    TESTCASE( NO_TESTDRIVER );
+    /* fsetpos() tested together with fsetpos(). */
     return TEST_RESULTS;
 }