]> 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 4820f73b3ddf89b0d2014bd3a25cc9fccdabde20..5a78706731d7f8ee355fdf2e0a4acc55da34bdbf 100644 (file)
@@ -9,9 +9,10 @@
 #include <stdio.h>
 
 #ifndef REGTEST
-#include <_PDCLIB_glue.h>
+#include <_PDCLIB_io.h>
 
-int fsetpos( struct _PDCLIB_file_t * stream, const struct _PDCLIB_fpos_t * pos )
+int _PDCLIB_fsetpos_unlocked( FILE * stream, 
+                      const _PDCLIB_fpos_t * pos )
 {
     if ( stream->status & _PDCLIB_FWRITE )
     {
@@ -24,10 +25,20 @@ int fsetpos( struct _PDCLIB_file_t * stream, const struct _PDCLIB_fpos_t * pos )
     {
         return EOF;
     }
-    stream->pos.status = pos->status;
+    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
@@ -35,7 +46,7 @@ int fsetpos( struct _PDCLIB_file_t * stream, const struct _PDCLIB_fpos_t * pos )
 
 int main( void )
 {
-    TESTCASE( NO_TESTDRIVER );
+    /* fsetpos() tested together with fsetpos(). */
     return TEST_RESULTS;
 }