Почему chdir() не работает?

Я кодирую базовую оболочку, и мое первое требование - проверить cd, у меня есть все условия для возможных команд cd, после чего я буду передавать такие команды, как ls. На данный момент я действительно запутался в одном блоке кода.

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

 #define MAX_TOK 50
 #define MAX_LEN 100
 #define BUFSIZE 81

 int tokenize(char *cmd, char tokens[MAX_TOK][MAX_LEN]){
     char *token;
     int NUM_TOKENS = 0;
     //printf("Splitting the string \"%s\" into tokens:\n",cmd);
     token = strtok(cmd, " ");

    while(token != NULL){
         strcpy(tokens[NUM_TOKENS],token);
         token = strtok(NULL, " ");
         NUM_TOKENS++;
     }
      return NUM_TOKENS;
  }

void decide(char tokens[MAX_TOK][MAX_LEN], int NUM_TOKENS){

    char *home = getenv("HOME");
    int success;
    char *cd = {"cd"};
    char *string = tokens[1];
    //printf("Number of tokens %d\n", NUM_TOKENS);
    //printf("%d\n",strcmp(tokens[0], cd));

    if(strcmp(tokens[0], cd) == 0){
        if(NUM_TOKENS > 2){
            printf("error: Too many arguments\n");
        }
        else{
           printf("Changing to new directory %s \n",tokens[1]);
           char *string = tokens[0];
           //printf("%s\n", tokens[1]);
           success = chdir(tokens[1]);
           printf("%d\n",success);
        }
    }
    else{
        printf("Completing the %s request\n",tokens[0]);
        take_action(tokens[0]);
    } 
 }

void take_action(char *cmd){
     printf("%s\n",cmd);
     int len;
     int return_code;
     char buffer[BUFSIZE];
     int pid;
     pid = fork();
     if(pid != 0){
         //parent process executing
         wait(NULL);
     }else{
         //child process executing
         len = strlen(buffer);
         if(buffer[len-1] == '\n'){
         buffer[len-1] = '\0';
       }
    return_code = execlp(cmd, cmd, NULL);
    if(return_code != 0){
        printf("Error executing %s.\n", cmd);
    }
   }//end else
}

int main(){
char *cmd;
char tokens[MAX_TOK][MAX_LEN];
int len;
int return_code;
char buffer[BUFSIZE];
int pid;

while(cmd != NULL){
    printf("Enter a command\n");
    cmd = fgets(buffer, BUFSIZE, stdin);
    // find the command
    int NUM_TOKENS = tokenize(cmd, tokens);
    //print_tokens(NUM_TOKENS, tokens);
    decide(tokens,NUM_TOKENS);
}



}//end main

При жестком кодировании chdir("test") код работает нормально, если пользователь в командной строке вводит "cd test"tokens[0] является cd а также tokens[1] это строка "test" но chdir(tokens[1]) не получается и я не понимаю почему.

Печать токенов [1] также показывает "тест" как сохраненную строку. Также при передаче параметра в take_action мне сообщают, что возникают конфликтующие типы. В обоих операторах печати указана правильная строка. Насколько я могу судить, здесь нет лишних пробелов, потому что моя функция токенизации удаляет их все. Я так растерялся, эти две части кажутся такими простыми, но просто не работают.

3 ответа

Решение

Пользователь не входит cd test, Он входит cd test и затем нажимает клавишу Enter.

Это означает, что у вас будет:

token[0] = "cd";
token[1] = "test\n";

И у вас нет каталога с именем "test\n", это было бы "test", Вам нужно убрать символ новой строки в последнем токене.

например, изменить основной, чтобы сделать

char *tmp;
cmd = fgets(buffer, BUFSIZE, stdin);
if (cmd && (tmp = strrchr(buffer, '\n')) != NULL) {
   *tmp = 0;
}

Код

char *string = tokens[0];
printf("%s\n", tokens[1]);
success = chdir(string);

будет переводить на

success = chdir("cd");

Я думаю, что вы хотели

char *string = tokens[1];
//                    ^

вместо.

token[0] является cd а также token[1] это path, Так что используйте char* string=token[1]

Другие вопросы по тегам