这是我的代码,我是西班牙语学生,我无法正确解释,但是,我需要在我自己的shell中实现cd命令。 对于工人阶级,如果有人可以帮助实现它。 当我把if条件放在进程上时,cd不起作用,但是当我把代码放在外面时我得到cd工作,但是,当放回cd时不会返回到前一个目录,因为cd命令通常会做。
如果有任何可以纠正失败。非常感谢你。
#include <fcntl.h>
#include <stdio.h>
#include <errno.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <libgen.h>
#include <sys/shm.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/wait.h>
#define TAM 1000
void parseo(char *line, char **argv);
int main(void) {
char cad[TAM];
char *argv[TAM];
char *gdir;
char *dir;
char *to;
char buf[TAM];
pid_t pid;
int status;
while (1) {
printf("user@PC: ");
fgets(cad, 1000, stdin);
// Si encontramos un salto de linea (se pulsa enter)
if (cad[strlen(cad) - 1] == '\n')
cad[strlen(cad) - 1] = '\0'; // lo marcamos como final de sentencia
parseo(cad, argv);
// Exit para salir del shell
if (!strcmp(argv[0], "exit")) exit(0);
if (!strcmp(argv[0], "cd")){
gdir = getcwd(buf, sizeof(buf));
dir = strcat(gdir, "/");
to = strcat(dir, argv[1]);
chdir(to);
//printf("Acceso a la carpeta realizado\n");
}
pid = fork();
if (pid == 0) {
if (execvp(*argv, argv) < 0) {
printf("%s: no se encontró la orden \n", argv[0]);
exit(1);
}
}else {
waitpid(pid,&status,0);
}
}
return 0;
}
void parseo(char *line, char **argv){
while (*line != '\0') {
while (*line == ' ' || *line == '\t' || *line == '\n')
*line++ = '\0';
*argv++ = line;
while (*line != '\0' && *line != ' ' && *line != '\t' && *line != '\n')
line++;
}
*argv = '\0'; // marca de final
}
答案 0 :(得分:1)
实际上工作正常!唯一的问题是,在调用array
之后,您的代码继续将该命令解析为外部可执行文件,该文件失败。你没有chdir()
的这个问题,因为它在它可以执行任何其他操作之前退出shell。 :)
将后面的代码移到exit
块中,或者在else
之后添加continue
,应该修复它。
(顺便说一句:chdir()
之前的getcwd()
/ strcat()
步骤实际上是不必要的。chdir()
使用相对路径:例如,如果当前工作目录是chdir()
,您可以致电/usr
输入chdir("bin")
。)