1
0
Fork 0
mirror of https://github.com/eclipse-cdt/cdt synced 2025-08-10 01:35:39 +02:00

Reformat to be Unix format. Check the program

with pfind() to see if executable.
This commit is contained in:
Alain Magloire 2002-10-17 15:52:34 +00:00
parent e1b17f11c1
commit b968757017

View file

@ -8,7 +8,7 @@
#include <stdlib.h> #include <stdlib.h>
/* from pfind.c */ /* from pfind.c */
char *pfind( char *name ); extern char *pfind(const char *name);
pid_t pid_t
exec0(const char *path, char *const argv[], char *const envp[], exec0(const char *path, char *const argv[], char *const envp[],
@ -18,25 +18,20 @@ exec0(const char *path, char *const argv[], char *const envp[],
pid_t childpid; pid_t childpid;
char *full_path; char *full_path;
// /*
// Handle this error case, we need the full path for execve() below. * We use pfind() to check that the program exists and is an executable.
// * If not pass the error up.
if (path[0] != '/' && path[0] != '.') { */
full_path = pfind( path ); full_path = pfind(path);
//full_path = pathfind (getenv ("PATH"), path, "rx");
if (full_path == NULL) { if (full_path == NULL) {
fprintf( stderr, "Unable to find full path for \"%s\"\n", path ); fprintf(stderr, "Unable to find full path for \"%s\"\n", path);
return -1; return -1;
} }
} else {
full_path = strdup(path);
}
// /*
// Make sure we can create our pipes before forking. * Make sure we can create our pipes before forking.
// */
if( channels != NULL ) if (channels != NULL) {
{
if (pipe(pipe0) < 0 || pipe(pipe1) < 0 || pipe(pipe2) < 0) { if (pipe(pipe0) < 0 || pipe(pipe1) < 0 || pipe(pipe2) < 0) {
fprintf(stderr, "%s(%d): returning due to error.\n", fprintf(stderr, "%s(%d): returning due to error.\n",
__FUNCTION__, __LINE__); __FUNCTION__, __LINE__);
@ -57,19 +52,18 @@ exec0(const char *path, char *const argv[], char *const envp[],
chdir(dirpath); chdir(dirpath);
if( channels != NULL ) if (channels != NULL) {
{
/* Close the write end of pipe0 */ /* Close the write end of pipe0 */
if( close(pipe0[1]) == -1 ) if (close(pipe0[1]) == -1)
perror( "close(pipe0[1])" ); perror("close(pipe0[1])");
/* Close the read end of pipe1 */ /* Close the read end of pipe1 */
if( close(pipe1[0]) == -1 ) if (close(pipe1[0]) == -1)
perror( "close(pipe1[0])" ); perror("close(pipe1[0])");
/* Close the read end of pipe2 */ /* Close the read end of pipe2 */
if( close(pipe2[0]) == -1 ) if (close(pipe2[0]) == -1)
perror( "close(pipe2[0]))" ); perror("close(pipe2[0]))");
/* redirections */ /* redirections */
dup2(pipe0[0], STDIN_FILENO); /* dup stdin */ dup2(pipe0[0], STDIN_FILENO); /* dup stdin */
@ -86,13 +80,10 @@ exec0(const char *path, char *const argv[], char *const envp[],
close(fd++); close(fd++);
} }
if( envp[0] == NULL ) if (envp[0] == NULL) {
{ execv(full_path, argv);
execv( full_path, argv ); } else {
} execve(full_path, argv, envp);
else
{
execve( full_path, argv, envp );
} }
_exit(127); _exit(127);
@ -101,19 +92,18 @@ exec0(const char *path, char *const argv[], char *const envp[],
char b; char b;
if( channels != NULL ) if (channels != NULL) {
{
/* close the read end of pipe1 */ /* close the read end of pipe1 */
if( close(pipe0[0]) == -1 ) if (close(pipe0[0]) == -1)
perror( "close(pipe0[0])" ); perror("close(pipe0[0])");
/* close the write end of pipe2 */ /* close the write end of pipe2 */
if( close(pipe1[1]) == -1 ) if (close(pipe1[1]) == -1)
perror( "close(pipe1[1])" ); perror("close(pipe1[1])");
/* close the write end of pipe2 */ /* close the write end of pipe2 */
if( close(pipe2[1]) == -1 ) if (close(pipe2[1]) == -1)
perror( "close(pipe2[1])" ); perror("close(pipe2[1])");
channels[0] = pipe0[1]; /* Output Stream. */ channels[0] = pipe0[1]; /* Output Stream. */
channels[1] = pipe1[0]; /* Input Stream. */ channels[1] = pipe1[0]; /* Input Stream. */