popen
definitely does the job that you're looking for, but it has a few drawbacks:
- It invokes a shell on the command you're executing (which means that you need to untaint any user provided command strings)
- It only works in one direction, either you can provide input to the subprocess or you can read its output.
If you want invoke a subprocess and provide input and capture output then you'll have to do something like this:
int Input[2], Output[2];
pipe( Input );
pipe( Output );
if( fork() )
{
// We're in the parent here.
// Close the reading end of the input pipe.
close( Input[ 0 ] );
// Close the writing end of the output pipe
close( Output[ 1 ] );
// Here we can interact with the subprocess. Write to the subprocesses stdin via Input[ 1 ], and read from the subprocesses stdout via Output[ 0 ].
...
}
else
{ // We're in the child here.
close( Input[ 1 ] );
dup2( Input[ 0 ], STDIN_FILENO );
close( Output[ 0 ] );
dup2( Output[ 1 ], STDOUT_FILENO );
execlp( "ls", "-la", NULL );
}
Of course, you can replace the execlp
with any of the other exec functions as appropriate.