summaryrefslogtreecommitdiff
path: root/lib/System
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2006-08-22 15:56:52 +0000
committerReid Spencer <rspencer@reidspencer.com>2006-08-22 15:56:52 +0000
commitad42ea73563c204285f47fbf598b01915d2f3044 (patch)
tree9a9f35506d9b6919b16c0b93ec1e6c25dc28779d /lib/System
parentf4d40050f1dc6488b5f706b95a2c8657f5a97c2f (diff)
downloadllvm-ad42ea73563c204285f47fbf598b01915d2f3044.tar.gz
llvm-ad42ea73563c204285f47fbf598b01915d2f3044.tar.bz2
llvm-ad42ea73563c204285f47fbf598b01915d2f3044.tar.xz
For PR797:
Fix a bug in my last patch that botched file redirection by using explicit scoping of if statements. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29815 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/System')
-rw-r--r--lib/System/Unix/Program.inc21
1 files changed, 13 insertions, 8 deletions
diff --git a/lib/System/Unix/Program.inc b/lib/System/Unix/Program.inc
index 97aa804b3c..5961dae5ad 100644
--- a/lib/System/Unix/Program.inc
+++ b/lib/System/Unix/Program.inc
@@ -133,22 +133,27 @@ Program::ExecuteAndWait(const Path& path,
case 0: {
// Redirect file descriptors...
if (redirects) {
- if (redirects[0])
- if (redirects[0]->isEmpty())
+ if (redirects[0]) {
+ if (redirects[0]->isEmpty()) {
if (RedirectFD("/dev/null",0,ErrMsg)) { return -1; }
- else
+ } else {
if (RedirectFD(redirects[0]->toString(), 0,ErrMsg)) { return -1; }
- if (redirects[1])
- if (redirects[1]->isEmpty())
+ }
+ }
+ if (redirects[1]) {
+ if (redirects[1]->isEmpty()) {
if (RedirectFD("/dev/null",1,ErrMsg)) { return -1; }
- else
+ } else {
if (RedirectFD(redirects[1]->toString(),1,ErrMsg)) { return -1; }
+ }
+ }
if (redirects[1] && redirects[2] &&
*(redirects[1]) != *(redirects[2])) {
- if (redirects[2]->isEmpty())
+ if (redirects[2]->isEmpty()) {
if (RedirectFD("/dev/null",2,ErrMsg)) { return -1; }
- else
+ } else {
if (RedirectFD(redirects[2]->toString(), 2,ErrMsg)) { return -1; }
+ }
} else if (-1 == dup2(1,2)) {
MakeErrMsg(ErrMsg, "Can't redirect");
return -1;