DOKK / manpages / debian 11 / libexecs-dev / coprocess.3.en
coprocess(3) Linux Programmer's Manual coprocess(3)

coprocv, coprocvp, coprocvpe, coprocs, coprocsp - execute a command in coprocessing mode

#include <execs.h>

pid_t coprocv(const char *path, char *const argv[], int pipefd[2]);
pid_t coprocve(const char *path, char *const argv[],
char *const envp[], int pipefd[2]);
pid_t coprocvp(const char *file, char *const argv[], int pipefd[2]);
pid_t coprocvpe(const char *file, char *const argv[],
char *const envp[], int pipefd[2]);

pid_t coprocs(const char *path, const char *command, int pipefd[2]);
pid_t coprocse(const char *path, const char *command,
char *const envp[], int pipefd[2]);
pid_t coprocsp(const char *command, int pipefd[2]);
pid_t coprocspe(const char *command, char *const envp[],
int pipefd[2]);

These functions are provided by libexecs. Link with -lexecs.

These functions run commands in coprocessing mode. They differs in the way to specify the executable file to run and its parameters. All of them define two pipes (by pipe(2)), create a new process by fork(2), redirect the standard input and output of the new process in the two pipes, and exec a program by one of the exec(3) functions.

The calling program controls both the standard input and the standard output of the called process: writing to pipefd[1] provides input to the coprocess while the coprocess output can be retrieved from pipefd[0].

coprocv, coprocve, coprocvp, coprocvpe, coprocs, coprocse, coprocsp, and coprocsp differ as they define the executable file to run and its arguments as execv, execve, execvp, execvpe, execs, execse, execsp, and execsp, respectively.

Bug reports should be addressed to <info@virtualsquare.org>

Renzo Davoli <renzo@cs.unibo.it>

2014-05-27 VirtualSquare