summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2005-04-21 20:05:09 (GMT)
committerBrad King <brad.king@kitware.com>2005-04-21 20:05:09 (GMT)
commit8567e7d0bc0595824cfd99ecc1e31b23ad189e8a (patch)
tree69323777aa38bd7405010bd888b816d59ac64e20
parent3f224b755805cac375fecb13da08c17b188fae01 (diff)
downloadCMake-8567e7d0bc0595824cfd99ecc1e31b23ad189e8a.zip
CMake-8567e7d0bc0595824cfd99ecc1e31b23ad189e8a.tar.gz
CMake-8567e7d0bc0595824cfd99ecc1e31b23ad189e8a.tar.bz2
BUG: Do not close stdout/stderr pipes in parent if they are shared.
-rw-r--r--Source/kwsys/ProcessUNIX.c10
-rw-r--r--Source/kwsys/ProcessWin32.c7
2 files changed, 13 insertions, 4 deletions
diff --git a/Source/kwsys/ProcessUNIX.c b/Source/kwsys/ProcessUNIX.c
index 31e34ed..262d2df 100644
--- a/Source/kwsys/ProcessUNIX.c
+++ b/Source/kwsys/ProcessUNIX.c
@@ -689,7 +689,10 @@ void kwsysProcess_Execute(kwsysProcess* cp)
}
/* The parent process does not need the output pipe write ends. */
- kwsysProcessCleanupDescriptor(&si.StdErr);
+ if(si.StdErr != 2)
+ {
+ kwsysProcessCleanupDescriptor(&si.StdErr);
+ }
kwsysProcessCleanupDescriptor(&si.TermPipe);
/* Restore the working directory. */
@@ -1395,7 +1398,10 @@ static int kwsysProcessCreate(kwsysProcess* cp, int prIndex,
}
/* The parent process does not need the output pipe write ends. */
- kwsysProcessCleanupDescriptor(&si->StdOut);
+ if(si->StdOut != 1)
+ {
+ kwsysProcessCleanupDescriptor(&si->StdOut);
+ }
return 1;
}
diff --git a/Source/kwsys/ProcessWin32.c b/Source/kwsys/ProcessWin32.c
index 730448a..922da17 100644
--- a/Source/kwsys/ProcessWin32.c
+++ b/Source/kwsys/ProcessWin32.c
@@ -1160,7 +1160,7 @@ void kwsysProcess_Execute(kwsysProcess* cp)
{
kwsysProcessCleanupHandle(&si.StartupInfo.hStdOutput);
}
- if(si.StartupInfo.hStdOutput != GetStdHandle(STD_ERROR_HANDLE))
+ if(si.StartupInfo.hStdError != GetStdHandle(STD_ERROR_HANDLE))
{
kwsysProcessCleanupHandle(&si.StartupInfo.hStdError);
}
@@ -1176,7 +1176,10 @@ void kwsysProcess_Execute(kwsysProcess* cp)
/* Close the inherited handles to the stderr pipe shared by all
processes in the pipeline. */
- kwsysProcessCleanupHandle(&si.StartupInfo.hStdError);
+ if(si.StartupInfo.hStdError != GetStdHandle(STD_ERROR_HANDLE))
+ {
+ kwsysProcessCleanupHandle(&si.StartupInfo.hStdError);
+ }
/* Restore the working directory. */
if(cp->RealWorkingDirectory)