summaryrefslogtreecommitdiffstats
path: root/Source/cmWin32ProcessExecution.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmWin32ProcessExecution.cxx')
-rw-r--r--Source/cmWin32ProcessExecution.cxx72
1 files changed, 37 insertions, 35 deletions
diff --git a/Source/cmWin32ProcessExecution.cxx b/Source/cmWin32ProcessExecution.cxx
index 9670e42..f870676 100644
--- a/Source/cmWin32ProcessExecution.cxx
+++ b/Source/cmWin32ProcessExecution.cxx
@@ -256,7 +256,6 @@ bool cmWin32ProcessExecution::PrivateOpen(const char *cmdstring,
BOOL fSuccess;
int fd1, fd2, fd3;
//FILE *f1, *f2, *f3;
- long file_count;
saAttr.nLength = sizeof(SECURITY_ATTRIBUTES);
saAttr.bInheritHandle = TRUE;
@@ -369,25 +368,26 @@ bool cmWin32ProcessExecution::PrivateOpen(const char *cmdstring,
PERROR("CloseHandle");
break;
}
- file_count = 1;
break;
case POPEN_2:
case POPEN_4:
if ( 1 )
{
- char *m1, *m2;
+ // Comment this out. Maybe we will need it in the future.
+ // file IO access to the process might be cool.
+ //char *m1, *m2;
- if (mode && _O_TEXT)
- {
- m1 = "r";
- m2 = "w";
- }
- else
- {
- m1 = "rb";
- m2 = "wb";
- }
+ //if (mode && _O_TEXT)
+ // {
+ // m1 = "r";
+ // m2 = "w";
+ // }
+ //else
+ // {
+ // m1 = "rb";
+ // m2 = "wb";
+ // }
fd1 = _open_osfhandle(TO_INTPTR(hChildStdinWrDup), mode);
//f1 = _fdopen(fd1, m2);
@@ -401,25 +401,26 @@ bool cmWin32ProcessExecution::PrivateOpen(const char *cmdstring,
PERROR("CloseHandle");
}
- file_count = 2;
break;
}
case POPEN_3:
if ( 1)
{
- char *m1, *m2;
+ // Comment this out. Maybe we will need it in the future.
+ // file IO access to the process might be cool.
+ //char *m1, *m2;
- if (mode && _O_TEXT)
- {
- m1 = "r";
- m2 = "w";
- }
- else
- {
- m1 = "rb";
- m2 = "wb";
- }
+ //if (mode && _O_TEXT)
+ // {
+ // m1 = "r";
+ // m2 = "w";
+ // }
+ //else
+ // {
+ // m1 = "rb";
+ // m2 = "wb";
+ // }
fd1 = _open_osfhandle(TO_INTPTR(hChildStdinWrDup), mode);
@@ -430,7 +431,6 @@ bool cmWin32ProcessExecution::PrivateOpen(const char *cmdstring,
//f3 = _fdopen(fd3, m1);
PERROR("_open_osfhandle");
- file_count = 3;
break;
}
}
@@ -556,11 +556,10 @@ bool cmWin32ProcessExecution::PrivateClose(int timeout)
std::string output = "";
bool done = false;
- int stdoutloc = 0;
- int stderrloc = 0;
while(!done)
{
Sleep(10);
+ bool have_some = false;
struct _stat fsout;
struct _stat fserr;
int rout = _fstat(this->m_pStdOut, &fsout);
@@ -572,7 +571,6 @@ bool cmWin32ProcessExecution::PrivateClose(int timeout)
if (fserr.st_size > 0)
{
//std::cout << "Some error" << std::endl;
- int dist = fserr.st_size;
char buffer[1023];
int len = read(this->m_pStdErr, buffer, 1023);
buffer[len] = 0;
@@ -581,11 +579,11 @@ bool cmWin32ProcessExecution::PrivateClose(int timeout)
std::cout << buffer << std::flush;
}
output += buffer;
+ have_some = true;
}
if (fsout.st_size > 0)
{
//std::cout << "Some output" << std::endl;
- int dist = fsout.st_size;
char buffer[1023];
int len = read(this->m_pStdOut, buffer, 1023);
buffer[len] = 0;
@@ -594,14 +592,18 @@ bool cmWin32ProcessExecution::PrivateClose(int timeout)
std::cout << buffer << std::flush;
}
output += buffer;
+ have_some = true;
}
unsigned long exitCode;
- GetExitCodeProcess(hProcess,&exitCode);
- if (exitCode != STILL_ACTIVE)
+ if ( ! have_some )
{
- //std::cout << "STILL_ACTIVE = " << STILL_ACTIVE << std::endl;
- //std::cout << "Process is not active any more: " << exitCode << std::endl;
- break;
+ GetExitCodeProcess(hProcess,&exitCode);
+ if (exitCode != STILL_ACTIVE)
+ {
+ //std::cout << "STILL_ACTIVE = " << STILL_ACTIVE << std::endl;
+ //std::cout << "Process is not active any more: " << exitCode << std::endl;
+ break;
+ }
}
}