X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Ffreopen.c;h=c31e30c7fb19423b6b58a3df3b3e9787b6c9a6c9;hb=98716b76d5f78e8ea0670b841ca470dffefb53d9;hp=5da5cedaa979493c4f181fdeab56805a42064f50;hpb=b2e2010c7c902235b5efb5bd3c6529f61b093aa4;p=gnulib.git diff --git a/lib/freopen.c b/lib/freopen.c index 5da5cedaa..c31e30c7f 100644 --- a/lib/freopen.c +++ b/lib/freopen.c @@ -1,5 +1,5 @@ /* Open a stream to a file. - Copyright (C) 2007-2010 Free Software Foundation, Inc. + Copyright (C) 2007-2012 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 @@ -16,10 +16,13 @@ /* 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. */ -#define __need_FILE #include #undef __need_FILE @@ -30,7 +33,9 @@ orig_freopen (const char *filename, const char *mode, FILE *stream) } /* Specification. */ -#include +/* 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 @@ -38,7 +43,7 @@ FILE * rpl_freopen (const char *filename, const char *mode, FILE *stream) { #if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__ - if (strcmp (filename, "/dev/null") == 0) + if (filename != NULL && strcmp (filename, "/dev/null") == 0) filename = "NUL"; #endif