#include <stdio.h>
#ifndef REGTEST
-
+#include <_PDCLIB_io.h>
#include <_PDCLIB_glue.h>
#include <stdlib.h>
#include <string.h>
-struct _PDCLIB_file_t * freopen(
- const char * _PDCLIB_restrict filename,
- const char * _PDCLIB_restrict mode,
- struct _PDCLIB_file_t * _PDCLIB_restrict stream )
+FILE * freopen(
+ const char * _PDCLIB_restrict filename,
+ const char * _PDCLIB_restrict mode,
+ FILE * _PDCLIB_restrict stream
+)
{
- flockfile( stream );
+ _PDCLIB_flockfile( stream );
+
+ unsigned int status = stream->status &
+ ( _IONBF | _IOLBF | _IOFBF | _PDCLIB_FREEBUFFER
+ | _PDCLIB_DELONCLOSE | _PDCLIB_STATIC );
- unsigned int status = stream->status & ( _IONBF | _IOLBF | _IOFBF | _PDCLIB_FREEBUFFER | _PDCLIB_DELONCLOSE );
/* TODO: This function can change wide orientation of a stream */
if ( stream->status & _PDCLIB_FWRITE )
{
if ( ( filename == NULL ) && ( stream->filename == NULL ) )
{
/* TODO: Special handling for mode changes on std-streams */
- funlockfile( stream );
+ _PDCLIB_funlockfile( stream );
return NULL;
}
stream->ops->close(stream->handle);
It does not matter with the current implementation of clearerr(),
but it might start to matter if someone replaced that implementation.
*/
- clearerr( stream );
+ _PDCLIB_clearerr_unlocked( stream );
/* The new filename might not fit the old buffer */
if ( filename == NULL )
{
/* Allocate new buffer */
if ( ( stream->filename = (char *)malloc( strlen( filename ) ) ) == NULL )
{
- funlockfile( stream );
+ _PDCLIB_funlockfile( stream );
return NULL;
}
strcpy( stream->filename, filename );
}
if ( ( mode == NULL ) || ( filename[0] == '\0' ) )
{
- funlockfile( stream );
+ _PDCLIB_funlockfile( stream );
return NULL;
}
if ( ( stream->status = _PDCLIB_filemode( mode ) ) == 0 )
{
- funlockfile( stream );
+ _PDCLIB_funlockfile( stream );
return NULL;
}
/* Re-add the flags we saved above */
if ( ! _PDCLIB_open( &stream->handle, &stream->ops, filename,
stream->status ) )
{
- funlockfile( stream );
+ _PDCLIB_funlockfile( stream );
return NULL;
}
- funlockfile( stream );
+ _PDCLIB_funlockfile( stream );
return stream;
}