How to make chdir() stay in the specified directory after the program finishes?

7.4k Views Asked by At

I have a program that calls chdir() to change the cwd. However, after the program finishes the cwd changes back to the directory that called the program instead of staying the in one specified by the call to chdir(). I made a program to test if chdir() is actually changing to the specified directory and found that chdir() is doing what I presumed: changing to the specified directory for the duration of the program then returning to the directory that executed the program.

Here is the code for the test:

#include <stdio.h>
#include <unistd.h>

#define NAME_MAX 100

int main(int argc, char **argv)
{
    char buf[NAME_MAX];
    char *path = argv[1];

    if (chdir(path) == -1) { /* change cwd to path */   
        fprintf(stderr, "error: could not change to dir %s\n", path);
        return 1;
    }
    getcwd(buf, NAME_MAX);
    printf("CWD is: %s\n", buf); /* print cwd as obtained from getcwd() */

    return 0;
}

and here is the output from my terminal:

john@ubuntu:~/C/cli$ pwd
/home/john/C/cli
john@ubuntu:~/C/cli$ mkdir foobar
john@ubuntu:~/C/cli$ ./test.c foobar
CWD is: /home/john/C/cli/foobar
john@ubuntu:~/C/cli$ pwd
/home/john/C/cli

So my question is, how can I stay in the directory that I specify in the call to chdir() after the the program finishes? Also, I am on Ubuntu 12.04 and compiling with gcc.

2

There are 2 best solutions below

3
On BEST ANSWER

Certain information, including values of environment variables and the current working directory, is propagated from parent processes to child processes but not back to parent processes. If a child process (your program) invokes chdir or sets or modifies an environment variable, that affects that process and any of its children, but cannot affect the parent.

That's why chdir is a built-in command in the shell; it can't be implemented as a separate program.

If you want to have a program change your shell's current directory for you, you'll need to do it indirectly. For example, your program can print a cd command, and you can eval that output in your shell. (You can wrap that in a function.)

For example, if you change:

chdir(path);

to

printf("cd %s\n", path);

you can have a shell function:

my_func() {
    eval `your_program`
}

and my_func will change your shell's current directory.

Or you can put a cd command directly in the function, or in a script that you execute via . script-name or source script-name rather than executing it.

All these solutions require your current shell to execute the cd command itself (which internally invokes the chdir system call).

3
On

The environment of one process cannot be changed by another process. That includes the current working directory. So no, you can't stay in the directory.