我在C中创建了一个简单的minishell,除了cd
命令外,它可以正常工作。当我尝试运行它时,没有任何事情发生,除了它创建一个永远不会真正结束的子进程。例如,在我的minishell中运行cd
后,我需要输入exit
两次以退出minishell,而不是标准的一次。
码:
int debug = 0;
void safeQuit(){
if (debug==1)
printf("INFO: Parent process, pid=%d exiting.\n", getpid());
exit(0);
}
int main(int argc,char** argv)
{
int pid, stat;
char * Array_arg[50];
char command_line[200];//user input
if (argc>1)
if (strcmp(argv[1],"-debug")==0)
debug=1;
while (1){
printf("[minishell]> "+debug);
gets(command_line);
if (strcmp(command_line,"exit")==0)
safeQuit();
char * subcommand=strtok(command_line," "); //divides the string according to the spaces
int i=0;
while (subcommand!= NULL)//insert to array
{
Array_arg[i]=subcommand;
subcommand=strtok(NULL," ");
i++;
}
Array_arg[i]='\0';
if (fork()==0){
if (debug==1)
printf("INFO: child process, pid = %d, executing command %s\n", getpid(), command_line);
execvp(Array_arg[0],Array_arg); //execution of cmd
}
else{
pid=wait(&stat);
}
}
}
答案 0 :(得分:2)
cd
必须是内置的shell,而不是外部实用程序。您想要更改当前进程的当前工作目录(shell本身),而不是子进程的当前工作目录。拨打chdir,而不是分支子进程。
另外,检查execvp是否存在错误并在 exec 失败后防御性地终止该子项。如果你这样做,你会看到一个信息错误:
... (child) ...
execvp(Array_arg[0], Array_arg);
perror("Error - exec failed"); // If we are here, we did *not* replace the process image
exit(0);