3

I don't know what I am doing wrong... but here is the snippet of code that is being executed:

if (fork() == 0)
    {       
             // child
        int fd = open(fileName, O_RDWR | O_CREAT, S_IRUSR | S_IWUSR);

        dup2(fd, 1);   // make stdout go to file

        execvp("ls","ls");
        close(fd);
            exit(0);
    }
if(wait(&status) == -1)
    {
        printf("ERROR REDIRECT\n");
    }

fileName gets created but there is nothing inside.What am I doing wrong?

user1162954
  • 267
  • 2
  • 4
  • 7

2 Answers2

6

My guess is that the execvp doesn't work but since you don't handler errors you don't see it.

Try this:

char *const args[] = {"ls", NULL};
execvp(args[0], args);

/* If this is reached execvp failed. */

perror("execvp");

Alternatively you can use compound literals:

execvp("ls", (char *[]){"ls", NULL});

Second idea: try to run things normally, without redirect and see how it works.

cnicutar
  • 178,505
  • 25
  • 365
  • 392
  • I tried that and nothing gets printed... it seems that `execvp` gets executed succesfully. – user1162954 Jan 30 '12 at 20:23
  • @user1162954 - There is not a chance in the world your execvp is working. Take cnicutar fix and your stuff will work. – Duck Jan 31 '12 at 01:17
1

close fd before execvp. because the code after execvp never runs unless execvp fails.