Implementation of spawnl and spawnlp.

This commit is contained in:
Mike Bond 2001-05-18 20:58:08 +00:00 committed by Alexandre Julliard
parent 6d3e81b9e0
commit 2f3b2ec5e5
2 changed files with 82 additions and 2 deletions

View File

@ -442,9 +442,9 @@ debug_channels (msvcrt)
@ varargs _snprintf(str long str) snprintf @ varargs _snprintf(str long str) snprintf
@ forward -noimport _snwprintf ntdll._snwprintf @ forward -noimport _snwprintf ntdll._snwprintf
@ cdecl _sopen(str long long) MSVCRT__sopen @ cdecl _sopen(str long long) MSVCRT__sopen
@ stub _spawnl #(str str) varargs @ varargs _spawnl(str str) _spawnl
@ stub _spawnle #(str str) varargs @ stub _spawnle #(str str) varargs
@ stub _spawnlp #(str str) varargs @ varargs _spawnlp(str str) _spawnlp
@ stub _spawnlpe #(str str) varargs @ stub _spawnlpe #(str str) varargs
@ cdecl _spawnv(long str ptr) _spawnv @ cdecl _spawnv(long str ptr) _spawnv
@ cdecl _spawnve(long str ptr ptr) _spawnve @ cdecl _spawnve(long str ptr ptr) _spawnve

View File

@ -109,6 +109,45 @@ static char* msvcrt_argvtos(const char* const* arg, char delim)
return ret; return ret;
} }
/* INTERNAL: Convert va_list to a single 'delim'-separated string */
static char* msvcrt_valisttos(const char* arg0, va_list ap, char delim)
{
va_list search = ap;
long size;
char *arg;
char *ret;
int strsize;
if (!arg0 && !delim)
return NULL;
/* get length */
size = strlen(arg0) + 1;
while((arg = va_arg(search, char *)) != NULL)
{
size += strlen(arg) + 1;
}
if (!(ret = (char *)MSVCRT_calloc(size + 1, 1)))
return NULL;
/* fill string */
search = ap;
size = 0;
strsize = strlen(arg0);
memcpy(ret+size,arg0,strsize);
ret[size+strsize] = delim;
size += strsize + 1;
while((arg = va_arg(search, char *)) != NULL)
{
strsize = strlen(search);
memcpy(ret+size,search,strsize);
ret[size+strsize] = delim;
size += strsize + 1;
}
return ret;
}
/********************************************************************* /*********************************************************************
* _cwait (MSVCRT.@) * _cwait (MSVCRT.@)
*/ */
@ -142,6 +181,47 @@ int _cwait(int *status, int pid, int action)
return status ? *status = -1 : -1; return status ? *status = -1 : -1;
} }
/*********************************************************************
* _spawnl (MSVCRT.@)
*/
int _spawnl(int flags, const char* name, const char* arg0, ...)
{
va_list ap;
char * args;
int ret;
va_start(ap, arg0);
args = msvcrt_valisttos(arg0, ap, ' ');
va_end(ap);
ret = msvcrt_spawn(flags, name, args, NULL);
MSVCRT_free(args);
return ret;
}
/*********************************************************************
* _spawnl (MSVCRT.@)
*/
int _spawnlp(int flags, const char* name, const char* arg0, ...)
{
va_list ap;
char * args;
int ret;
char fullname[MAX_PATH];
_searchenv(name, "PATH", fullname);
va_start(ap, arg0);
args = msvcrt_valisttos(arg0, ap, ' ');
va_end(ap);
ret = msvcrt_spawn(flags, name, args, NULL);
MSVCRT_free(args);
return ret;
}
/********************************************************************* /*********************************************************************
* _spawnve (MSVCRT.@) * _spawnve (MSVCRT.@)
*/ */