Revert r235177 as the Handle is used to fail GetExitCodeProcess on purpose.
authorYaron Keren <yaron.keren@gmail.com>
Fri, 17 Apr 2015 12:11:15 +0000 (12:11 +0000)
committerYaron Keren <yaron.keren@gmail.com>
Fri, 17 Apr 2015 12:11:15 +0000 (12:11 +0000)
Avoid double closing of the handle by testing GetLastErr for
ERROR_INVALID_HANDLE and not calling CloseHandle(PI.ProcessHandle) then.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@235184 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Support/Windows/Program.inc

index 32602345f65d7945d15caabc974876af12994838..75685de4554768de9d0e0a150ef66d17a1943d8b 100644 (file)
@@ -423,6 +423,7 @@ ProcessInfo sys::Wait(const ProcessInfo &PI, unsigned SecondsToWait,
         return WaitResult;
       }
       WaitForSingleObject(PI.ProcessHandle, INFINITE);
+      CloseHandle(PI.ProcessHandle);
     } else {
       // Non-blocking wait.
       return ProcessInfo();
@@ -433,7 +434,8 @@ ProcessInfo sys::Wait(const ProcessInfo &PI, unsigned SecondsToWait,
   DWORD status;
   BOOL rc = GetExitCodeProcess(PI.ProcessHandle, &status);
   DWORD err = GetLastError();
-  CloseHandle(PI.ProcessHandle);
+  if (err != ERROR_INVALID_HANDLE)
+    CloseHandle(PI.ProcessHandle);
 
   if (!rc) {
     SetLastError(err);