/* Open a stream to a file.
Copyright (C) 2007-2016 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see . */
/* Written by Bruno Haible , 2007. */
/* If the user's config.h happens to include , let it include only
the system's here, so that orig_freopen doesn't recurse to
rpl_freopen. */
#define __need_FILE
#include
/* Get the original definition of freopen. It might be defined as a macro. */
#include
#undef __need_FILE
#include
static FILE *
orig_freopen (const char *filename, const char *mode, FILE *stream)
{
return freopen (filename, mode, stream);
}
/* Specification. */
/* Write "stdio.h" here, not , otherwise OSF/1 5.1 DTK cc eliminates
this include because of the preliminary #include above. */
#include "stdio.h"
#include
FILE *
rpl_freopen (const char *filename, const char *mode, FILE *stream)
{
FILE *result;
#if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
if (filename != NULL && strcmp (filename, "/dev/null") == 0)
filename = "NUL";
#endif
/* Clear errno to check the success of freopen() with it */
errno = 0;
result = orig_freopen (filename, mode, stream);
#ifdef __KLIBC__
/* On OS/2 kLIBC, freopen() returns NULL even if it is successful
if filename is NULL. */
if (!filename && !result && !errno)
result = stream;
#endif
return result;
}