From cf45ca04084e7888051cc6ec9c9c37e10a118ee6 Mon Sep 17 00:00:00 2001 From: Matthijs Kooijman Date: Thu, 12 Jun 2008 12:53:35 +0000 Subject: Fix redirection of stderr in sys::Program::ExecuteAndWait. There was logic error that caused it to redirect stderr to stdout too often. This fix is applied identically to the win32 code as well, but that is untested. --Thi line, and those below, will be ignored-- M System/Unix/Program.inc M System/Win32/Program.inc git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52233 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/System/Unix/Program.inc | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) (limited to 'lib/System/Unix') diff --git a/lib/System/Unix/Program.inc b/lib/System/Unix/Program.inc index 6ff69ca133..2426900578 100644 --- a/lib/System/Unix/Program.inc +++ b/lib/System/Unix/Program.inc @@ -170,14 +170,21 @@ Program::ExecuteAndWait(const Path& path, case 0: { // Redirect file descriptors... if (redirects) { + // Redirect stdin if (RedirectIO(redirects[0], 0, ErrMsg)) { return -1; } + // Redirect stdout if (RedirectIO(redirects[1], 1, ErrMsg)) { return -1; } if (redirects[1] && redirects[2] && - *(redirects[1]) != *(redirects[2])) { + *(redirects[1]) == *(redirects[2])) { + // If stdout and stderr should go to the same place, redirect stderr + // to the FD already open for stdout. + if (-1 == dup2(1,2)) { + MakeErrMsg(ErrMsg, "Can't redirect stderr to stdout"); + return -1; + } + } else { + // Just redirect stderr if (RedirectIO(redirects[2], 2, ErrMsg)) { return -1; } - } else if (-1 == dup2(1,2)) { - MakeErrMsg(ErrMsg, "Can't redirect"); - return -1; } } -- cgit v1.2.3-18-g5258