X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fcloseout.c;h=830f16f8ae8a6e7f6177b0ace34a387708e5043e;hb=fa662f811f9a6dda54f64639b107b1637c3ba2e5;hp=f298d4bed89ed00ea83fd3d8906a29fbae71d05a;hpb=cd6cd3bd41bf69ca65c62a2f96de0ed89cb3c16e;p=gnulib.git diff --git a/lib/closeout.c b/lib/closeout.c index f298d4bed..830f16f8a 100644 --- a/lib/closeout.c +++ b/lib/closeout.c @@ -1,4 +1,4 @@ -/* Close standard output, exiting with a diagnostic on error. +/* Close standard output and standard error, exiting with a diagnostic on error. Copyright (C) 1998, 1999, 2000, 2001, 2002, 2004, 2006 Free Software Foundation, Inc. @@ -17,9 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -#ifdef HAVE_CONFIG_H -# include -#endif +#include #include "closeout.h" @@ -48,6 +46,8 @@ close_stdout_set_file_name (const char *file) /* Close standard output. On error, issue a diagnostic and _exit with status 'exit_failure'. + Also close standard error. On error, _exit with status 'exit_failure'. + Since close_stdout is commonly registered via 'atexit', POSIX and the C standard both say that it should not call 'exit', because the behavior is undefined if 'exit' is called more than @@ -80,4 +80,7 @@ close_stdout (void) _exit (exit_failure); } + + if (close_stream (stderr) != 0) + _exit (exit_failure); }