Added execvpe().
* This closes #12114 again; while not POSIX, it's just a line away. * Removed exect() from the header -- not sure where this came from. but I can't find anything about it on the net. * Consolidated use of asterisk style in exec.cpp.
This commit is contained in:
parent
edade0f506
commit
34671d601a
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright 2004-2011 Haiku, Inc. All Rights Reserved.
|
||||
* Copyright 2004-2015 Haiku, Inc. All Rights Reserved.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*/
|
||||
#ifndef _UNISTD_H_
|
||||
|
@ -207,13 +207,15 @@ extern int lockf(int fd, int function, off_t size);
|
|||
/* process functions */
|
||||
extern pid_t fork(void);
|
||||
extern pid_t vfork(void);
|
||||
extern int execve(const char *path, char * const argv[], char * const envp[]);
|
||||
extern int execve(const char *path, char * const argv[],
|
||||
char *const environment[]);
|
||||
extern int execl(const char *path, const char *arg, ...);
|
||||
extern int execv(const char *path, char *const *argv);
|
||||
extern int execv(const char *path, char *const argv[]);
|
||||
extern int execlp(const char *file, const char *arg, ...);
|
||||
extern int execle(const char *path, const char *arg , ... /*, char **envp */);
|
||||
extern int exect(const char *path, char *const *argv);
|
||||
extern int execvp(const char *file, char *const *argv);
|
||||
extern int execvp(const char *file, char *const argv[]);
|
||||
extern int execvpe(const char *file, char *const argv[],
|
||||
char *const environment[]);
|
||||
|
||||
extern void _exit(int status) __attribute__ ((noreturn));
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
/*
|
||||
* Copyright 2008, Ingo Weinhold, ingo_weinhold@gmx.de.
|
||||
* Copyright 2004-2005, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
|
||||
* Copyright 2004-2015, Axel Dörfler, axeld@pinc-software.de.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*/
|
||||
|
||||
|
@ -21,30 +21,30 @@
|
|||
|
||||
|
||||
static int
|
||||
count_arguments(va_list list, const char *arg, char ***_env)
|
||||
count_arguments(va_list list, const char* arg, char*** _env)
|
||||
{
|
||||
int count = 0;
|
||||
|
||||
while (arg != NULL) {
|
||||
count++;
|
||||
arg = va_arg(list, const char *);
|
||||
arg = va_arg(list, const char*);
|
||||
}
|
||||
|
||||
if (_env)
|
||||
*_env = va_arg(list, char **);
|
||||
*_env = va_arg(list, char**);
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
copy_arguments(va_list list, const char **args, const char *arg)
|
||||
copy_arguments(va_list list, const char** args, const char* arg)
|
||||
{
|
||||
int count = 0;
|
||||
|
||||
while (arg != NULL) {
|
||||
args[count++] = arg;
|
||||
arg = va_arg(list, const char *);
|
||||
arg = va_arg(list, const char*);
|
||||
}
|
||||
|
||||
args[count] = NULL;
|
||||
|
@ -53,7 +53,7 @@ copy_arguments(va_list list, const char **args, const char *arg)
|
|||
|
||||
|
||||
static int
|
||||
do_exec(const char *path, char * const args[], char * const environment[],
|
||||
do_exec(const char* path, char* const args[], char* const environment[],
|
||||
bool useDefaultInterpreter)
|
||||
{
|
||||
if (path == NULL || args == NULL) {
|
||||
|
@ -94,7 +94,7 @@ do_exec(const char *path, char * const args[], char * const environment[],
|
|||
}
|
||||
}
|
||||
|
||||
char **newArgs = NULL;
|
||||
char** newArgs = NULL;
|
||||
if (invoker[0] != '\0') {
|
||||
status = __parse_invoke_line(invoker, &newArgs, &args, &argCount, path);
|
||||
if (status < B_OK) {
|
||||
|
@ -128,25 +128,32 @@ do_exec(const char *path, char * const args[], char * const environment[],
|
|||
|
||||
|
||||
int
|
||||
execve(const char *path, char* const args[], char* const environment[])
|
||||
execve(const char* path, char* const args[], char* const environment[])
|
||||
{
|
||||
return do_exec(path, args, environment, false);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
execv(const char *path, char * const *argv)
|
||||
execv(const char* path, char* const argv[])
|
||||
{
|
||||
return do_exec(path, argv, environ, false);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
execvp(const char *file, char* const* argv)
|
||||
execvp(const char* file, char* const argv[])
|
||||
{
|
||||
return execvpe(file, argv, environ);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
execvpe(const char* file, char* const argv[], char* const environment[])
|
||||
{
|
||||
// let do_exec() handle cases where file is a path (or invalid)
|
||||
if (file == NULL || strchr(file, '/') != NULL)
|
||||
return do_exec(file, argv, environ, true);
|
||||
return do_exec(file, argv, environment, true);
|
||||
|
||||
// file is just a leaf name, so we have to look it up in the path
|
||||
|
||||
|
@ -189,7 +196,7 @@ execvp(const char *file, char* const* argv)
|
|||
|
||||
// if executable, execute it
|
||||
if (access(path, X_OK) == 0)
|
||||
return do_exec(path, argv, environ, true);
|
||||
return do_exec(path, argv, environment, true);
|
||||
}
|
||||
|
||||
__set_errno(B_ENTRY_NOT_FOUND);
|
||||
|
@ -198,9 +205,9 @@ execvp(const char *file, char* const* argv)
|
|||
|
||||
|
||||
int
|
||||
execl(const char *path, const char *arg, ...)
|
||||
execl(const char* path, const char* arg, ...)
|
||||
{
|
||||
const char **args;
|
||||
const char** args;
|
||||
va_list list;
|
||||
int count;
|
||||
|
||||
|
@ -212,19 +219,19 @@ execl(const char *path, const char *arg, ...)
|
|||
|
||||
// copy arguments
|
||||
|
||||
args = (const char**)alloca((count + 1) * sizeof(char *));
|
||||
args = (const char**)alloca((count + 1) * sizeof(char*));
|
||||
va_start(list, arg);
|
||||
copy_arguments(list, args, arg);
|
||||
va_end(list);
|
||||
|
||||
return do_exec(path, (char * const *)args, environ, false);
|
||||
return do_exec(path, (char* const*)args, environ, false);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
execlp(const char *file, const char *arg, ...)
|
||||
execlp(const char* file, const char* arg, ...)
|
||||
{
|
||||
const char **args;
|
||||
const char** args;
|
||||
va_list list;
|
||||
int count;
|
||||
|
||||
|
@ -236,20 +243,20 @@ execlp(const char *file, const char *arg, ...)
|
|||
|
||||
// copy arguments
|
||||
|
||||
args = (const char**)alloca((count + 1) * sizeof(char *));
|
||||
args = (const char**)alloca((count + 1) * sizeof(char*));
|
||||
va_start(list, arg);
|
||||
copy_arguments(list, args, arg);
|
||||
va_end(list);
|
||||
|
||||
return execvp(file, (char * const *)args);
|
||||
return execvp(file, (char* const*)args);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
execle(const char *path, const char *arg, ... /*, char **env */)
|
||||
execle(const char* path, const char* arg, ... /*, char** env */)
|
||||
{
|
||||
const char **args;
|
||||
char **env;
|
||||
const char** args;
|
||||
char** env;
|
||||
va_list list;
|
||||
int count;
|
||||
|
||||
|
@ -261,19 +268,19 @@ execle(const char *path, const char *arg, ... /*, char **env */)
|
|||
|
||||
// copy arguments
|
||||
|
||||
args = (const char**)alloca((count + 1) * sizeof(char *));
|
||||
args = (const char**)alloca((count + 1) * sizeof(char*));
|
||||
va_start(list, arg);
|
||||
copy_arguments(list, args, arg);
|
||||
va_end(list);
|
||||
|
||||
return do_exec(path, (char * const *)args, env, false);
|
||||
return do_exec(path, (char* const*)args, env, false);
|
||||
}
|
||||
|
||||
// TODO: remove this again if possible
|
||||
extern int exect(const char *path, char *const *argv);
|
||||
|
||||
int
|
||||
exect(const char *path, char * const *argv)
|
||||
exect(const char* path, char* const* argv)
|
||||
{
|
||||
// ToDo: is this any different?
|
||||
return execv(path, argv);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue