Вот как бы я это сделал.Это довольно просто и оставляет сложную часть фактического копирования инструменту cp
, который успешно выполнял эту задачу в течение нескольких лет.
#include <assert.h>
#include <string.h>
#include <sys/wait.h>
#include <unistd.h>
int
runvp(int *ret_status, const char *command, const char * const *argv)
{
pid_t pid;
int status;
char * const *execv_argv;
pid = fork();
if (pid == (pid_t) -1)
return -1;
if (pid == 0) {
/*
* Circumvent the C type conversion rules;
* see ISO C99: 6.5.16.1#6 for details.
*/
assert(sizeof(execv_argv) == sizeof(argv));
memcpy(&execv_argv, &argv, sizeof(execv_argv));
(void) execvp(command, execv_argv);
return -1;
}
if (waitpid(pid, &status, 0) == -1)
return -1;
*ret_status = status;
return 0;
}
Это оболочка для fork
и execvp
что я написал несколько лет назад.Это можно использовать так:
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char **argv) {
int exitcode;
const char *cmdline[] = {
"cp",
"--",
argv[1],
argv[2],
NULL
};
if (runvp(&exitcode, cmdline[0], cmdline) == -1) {
perror("runvp");
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}