>From a4015f0453aeb60cfa70dcdfbd78db62b3a79b62 Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Sat, 5 Jan 2019 18:02:32 -0800 Subject: [PATCH 2/4] stdopen: modernize and simplify * lib/stdopen.c: Update copyright date Do not include sys/types.h; no longer needed these days. (stdopen): Use C99-style decl in loop. Return int errno value, rather than just a bool. Do not worry about fd mismatches, since the caller cares only if 0, 1, 2 are occupied. * lib/stdopen.h: No need to include . * m4/stdopen.m4: Remove. * modules/stdopen: New file. --- ChangeLog | 10 ++++++++ lib/stdopen.c | 63 +++++++++++++++++++++---------------------------- lib/stdopen.h | 4 +--- m4/stdopen.m4 | 13 ---------- modules/stdopen | 24 +++++++++++++++++++ 5 files changed, 62 insertions(+), 52 deletions(-) delete mode 100644 m4/stdopen.m4 create mode 100644 modules/stdopen diff --git a/ChangeLog b/ChangeLog index 72d75ef26..16ad6f169 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,15 @@ 2019-01-05 Paul Eggert + stdopen: modernize and simplify + * lib/stdopen.c: Update copyright date + Do not include sys/types.h; no longer needed these days. + (stdopen): Use C99-style decl in loop. Return int errno + value, rather than just a bool. Do not worry about fd mismatches, + since the caller cares only if 0, 1, 2 are occupied. + * lib/stdopen.h: No need to include . + * m4/stdopen.m4: Remove. + * modules/stdopen: New file. + stdopen: copy from last use in coreutils * lib/stdopen.c, lib/stdopen.h, m4/stdopen.m4: New files, taken from their last commit in coreutils diff --git a/lib/stdopen.c b/lib/stdopen.c index e9b554485..3903224e6 100644 --- a/lib/stdopen.c +++ b/lib/stdopen.c @@ -1,6 +1,6 @@ /* stdopen.c - ensure that the three standard file descriptors are in use - Copyright (C) 2005, 2006 Free Software Foundation, Inc. + Copyright (C) 2005-2006, 2019 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 @@ -21,7 +21,6 @@ #include "stdopen.h" -#include #include #include #include @@ -31,44 +30,36 @@ are in use. Without this, each application would have to guard every call to open, dup, fopen, etc. with tests to ensure they don't use one of the special file numbers when opening a file. - Return false if at least one of the file descriptors is initially - closed and an attempt to reopen it fails. Otherwise, return true. */ -bool + Return zero if successful, an errno value if at least one of + the file descriptors is initially closed and could not be opened. */ + +int stdopen (void) { - int fd; - bool ok = true; - - for (fd = 0; fd <= 2; fd++) + for (int fd = STDIN_FILENO; fd <= STDERR_FILENO; fd++) { if (fcntl (fd, F_GETFD) < 0) - { - if (errno != EBADF) - ok = false; - else - { - static const int contrary_mode[] - = { O_WRONLY, O_RDONLY, O_RDONLY }; - int mode = contrary_mode[fd]; - int new_fd; - /* Open /dev/null with the contrary mode so that the typical - read (stdin) or write (stdout, stderr) operation will fail. - With descriptor 0, we can do even better on systems that - have /dev/full, by opening that write-only instead of - /dev/null. The only drawback is that a write-provoked - failure comes with a misleading errno value, ENOSPC. */ - if (mode == O_RDONLY - || (new_fd = open ("/dev/full", mode) != fd)) - new_fd = open ("/dev/null", mode); - if (new_fd != fd) - { - if (0 <= new_fd) - close (new_fd); - ok = false; - } - } - } + { + /* Open /dev/null with the contrary mode so that the typical + read (stdin) or write (stdout, stderr) operation will fail. + With descriptor 0, we can do even better on systems that + have /dev/full, by opening that write-only instead of + /dev/null. The only drawback is that a write-provoked + failure comes with a misleading errno value, ENOSPC. */ + int mode = fd == STDIN_FILENO ? O_WRONLY : O_RDONLY; + int full_fd = fd == STDIN_FILENO ? open ("/dev/full", mode) : -1; + int new_fd = full_fd < 0 ? open ("/dev/null", mode) : full_fd; + if (new_fd < 0) + return errno; + if (STDERR_FILENO < new_fd) + { + /* 0, 1, and 2 are already open somehow. + Our is not to reason why. */ + close (new_fd); + return 0; + } + } } - return ok; + return 0; } diff --git a/lib/stdopen.h b/lib/stdopen.h index d54e5f135..27901d397 100644 --- a/lib/stdopen.h +++ b/lib/stdopen.h @@ -1,13 +1,11 @@ #ifndef STDOPEN_H # define STDOPEN_H 1 -# include - # ifdef __cplusplus extern "C" { # endif -bool stdopen (void); +int stdopen (void); # ifdef __cplusplus } diff --git a/m4/stdopen.m4 b/m4/stdopen.m4 deleted file mode 100644 index b18c22ddf..000000000 --- a/m4/stdopen.m4 +++ /dev/null @@ -1,13 +0,0 @@ -#serial 1 -dnl Copyright (C) 2005 Free Software Foundation, Inc. -dnl This file is free software; the Free Software Foundation -dnl gives unlimited permission to copy and/or distribute it, -dnl with or without modifications, as long as this notice is preserved. - -AC_DEFUN([gl_STDOPEN], -[ - AC_LIBSOURCES([stdopen.c, stdopen.h]) - AC_LIBOBJ([stdopen]) - - dnl Prerequisites. -]) diff --git a/modules/stdopen b/modules/stdopen new file mode 100644 index 000000000..81de5765b --- /dev/null +++ b/modules/stdopen @@ -0,0 +1,24 @@ +Description: +Arrange for stdin/stdout/stderr to be open. + +Files: +lib/stdopen.c +lib/stdopen.h + +Depends-on: +fcntl +unistd + +configure.ac: + +Makefile.am: +lib_SOURCES += stdopen.c + +Include: +"stdopen.h" + +License: +GPL + +Maintainer: +all -- 2.20.1