mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-05 13:51:00 +08:00
expect.c (__gnat_expect_portable_execvp): New implementation.
2006-02-13 Pascal Obry <obry@adacore.com> * expect.c (__gnat_expect_portable_execvp): New implementation. The previous implementation was using the C runtime spawnve routine but the corresponding wait was using directly the Win32 API. This was causing some times a lock when waiting for an event using WaitForSingleObject in __gnat_waitpid. This new implementation uses the Win32 CreateProcess routine. Avoiding mixing C runtime and Win32 API fixes this problem. From-SVN: r111066
This commit is contained in:
parent
d48e258e71
commit
0273bbb409
@ -114,7 +114,61 @@ __gnat_expect_fork (void)
|
||||
void
|
||||
__gnat_expect_portable_execvp (int *pid, char *cmd, char *argv[])
|
||||
{
|
||||
*pid = (int) spawnve (_P_NOWAIT, cmd, argv, NULL);
|
||||
BOOL result;
|
||||
STARTUPINFO SI;
|
||||
PROCESS_INFORMATION PI;
|
||||
SECURITY_ATTRIBUTES SA;
|
||||
int csize = 1;
|
||||
char *full_command;
|
||||
int k;
|
||||
|
||||
/* compute the total command line length. */
|
||||
k = 0;
|
||||
while (argv[k])
|
||||
{
|
||||
csize += strlen (argv[k]) + 1;
|
||||
k++;
|
||||
}
|
||||
|
||||
full_command = (char *) malloc (csize);
|
||||
full_command[0] = '\0';
|
||||
|
||||
/* Startup info. */
|
||||
SI.cb = sizeof (STARTUPINFO);
|
||||
SI.lpReserved = NULL;
|
||||
SI.lpReserved2 = NULL;
|
||||
SI.lpDesktop = NULL;
|
||||
SI.cbReserved2 = 0;
|
||||
SI.lpTitle = NULL;
|
||||
SI.dwFlags = 0;
|
||||
SI.wShowWindow = SW_HIDE;
|
||||
|
||||
/* Security attributes. */
|
||||
SA.nLength = sizeof (SECURITY_ATTRIBUTES);
|
||||
SA.bInheritHandle = TRUE;
|
||||
SA.lpSecurityDescriptor = NULL;
|
||||
|
||||
k = 0;
|
||||
while (argv[k])
|
||||
{
|
||||
strcat (full_command, argv[k]);
|
||||
strcat (full_command, " ");
|
||||
k++;
|
||||
}
|
||||
|
||||
result = CreateProcess
|
||||
(NULL, (char *) full_command, &SA, NULL, TRUE,
|
||||
GetPriorityClass (GetCurrentProcess()), NULL, NULL, &SI, &PI);
|
||||
|
||||
free (full_command);
|
||||
|
||||
if (result == TRUE)
|
||||
{
|
||||
CloseHandle (PI.hThread);
|
||||
*pid = (int) PI.hProcess;
|
||||
}
|
||||
else
|
||||
*pid = -1;
|
||||
}
|
||||
|
||||
int
|
||||
|
Loading…
x
Reference in New Issue
Block a user