How to make chdir() stay in the specified director

2019-09-14 06:37发布

问题:

This question already has an answer here:

  • Change directory of parent process after exit [duplicate] 2 answers

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.

回答1:

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).



回答2:

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.