diff options
author | Qball Cow <qball@qballcow.nl> | 2007-08-19 16:42:52 +0000 |
---|---|---|
committer | Qball Cow <qball@qballcow.nl> | 2007-08-19 16:42:52 +0000 |
commit | d551fa7b3e0fd711794c5d490977fda30ba13d6f (patch) | |
tree | adaa3f9485ceca4e2419a6f9f5772cb5825bbd66 /src/log.c | |
parent | c42ff8e2d29d7da3f8790639964b3ca43c1d797a (diff) | |
download | mpd-d551fa7b3e0fd711794c5d490977fda30ba13d6f.tar.gz mpd-d551fa7b3e0fd711794c5d490977fda30ba13d6f.tar.xz mpd-d551fa7b3e0fd711794c5d490977fda30ba13d6f.zip |
Adding the simple patch 1534
git-svn-id: https://svn.musicpd.org/mpd/branches/q-mpd@6762 09075e82-0dd4-0310-85a5-a0d7c8717e4f
Diffstat (limited to 'src/log.c')
-rw-r--r-- | src/log.c | 8 |
1 files changed, 7 insertions, 1 deletions
@@ -40,7 +40,13 @@ static const char *err_filename; /* redirect stdin to /dev/null to work around a libao bug */ static void redirect_stdin(void) { - int fd; + int fd, st; + struct stat ss; + + if ((st = fstat(STDIN_FILENO, &ss)) < 0 || /* If STDIN is already closed (e.g. mpd launched in a non-interactive shell) */ + ! isatty(STDIN_FILENO)) { /* ... or FD 0 does not correspond to a tty device */ + return; /* ... do nothing and return. */ + } if ((fd = open("/dev/null", O_RDONLY)) < 0) FATAL("failed to open /dev/null %s\n", strerror(errno)); if (dup2(fd, STDIN_FILENO) < 0) |