From 0de138acb59e620e0a542ace665abce7df49439f Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Fri, 21 May 2010 01:22:20 -0700 Subject: [PATCH] improve test for stdio non-blockingness --- src/node_stdio.cc | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/src/node_stdio.cc b/src/node_stdio.cc index a68d302fd1..94ee73a961 100644 --- a/src/node_stdio.cc +++ b/src/node_stdio.cc @@ -65,19 +65,27 @@ static Handle OpenStdin(const Arguments& args) { return scope.Close(Integer::New(STDIN_FILENO)); } -static Handle -IsStdinBlocking (const Arguments& args) -{ - HandleScope scope; - return scope.Close(Boolean::New(!isatty(STDIN_FILENO))); + +static bool IsBlocking(int fd) { + if (isatty(fd)) return false; + struct stat s; + if (fstat(fd, &s)) { + perror("fstat"); + return true; + } + if (s.st_mode & S_IFSOCK == S_IFSOCK) return false; + if (s.st_mode & S_IFIFO == S_IFIFO) return false; + return true; } -static Handle -IsStdoutBlocking (const Arguments& args) -{ - HandleScope scope; - bool tty = isatty(STDOUT_FILENO); - return scope.Close(Boolean::New(!tty)); + +static Handle IsStdinBlocking(const Arguments& arg) { + return IsBlocking(STDIN_FILENO) ? True() : False(); +} + + +static Handle IsStdoutBlocking(const Arguments& args) { + return IsBlocking(STDOUT_FILENO) ? True() : False(); }