Что может быть не так, ls не работает на моей собственной оболочке - PullRequest
0 голосов
/ 18 января 2020

Я должен написать свою собственную оболочку, и она почти завершена, но у меня проблема с ls / pwd

ls выдает мне эту ошибку: не может получить доступ '': нет такого файла или каталога

pwd работает каким-то образом, но все равно выдает ошибку: игнорирование аргументов без опций

https://i.stack.imgur.com/3IpRd.png В чем может быть проблема?

#include <sys/types.h>
#include <sys/wait.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
void  parsowanie(char *line, char **argv)
{
    while (*line != '\0') {
        while (*line == ' ' || *line == '\n'|| *line == '\t' )

            *line++ = '\0';
            *argv++ = line;

        while (*line != '\0' && *line!= ' ' && *line != '\t' && *line != '\n')
            line++;
    }
    *argv = '\0';
}
int main()
{

    printf("MicroShell\nAutor:Amadeusz Lewandowski\n");
    char co_chcesz[500],cwd[500],login[50],*argv[1000],*to;
    memset(argv,0,999);
    pid_t pid;
    int status;
    while(strcmp(co_chcesz,"exit\n"))
        {
        sleep(1);
        getcwd(cwd,sizeof(cwd));
        getlogin_r(login,sizeof(login));
        printf("[%s:%s]\n$ ",login,cwd);
        fgets(co_chcesz,1000,stdin);
        if (strcmp(co_chcesz,"help\n")==0)
            {
            printf("autor to miranda orange\n");
            continue;
            }
        pid=fork();

        if(pid==0)
        {
            if (execvp(*argv,argv)<0)
            {
                perror("The following error occurred");
                printf("Value of errno:%d\n",errno);
                    break;
            }
            else
            {
            waitpid(pid,&status,0);
            }
        }
    }
    return 0;
}

1 Ответ

0 голосов
/ 19 января 2020

Ваша функция разделения командной строки неверна. Переформатированный здесь, чтобы лучше показать, как это было реализовано:

void  parsowanie(char *line, char **argv)
{
    while (*line != '\0') {
        /* Eating whitespace */
        while (*line == ' ' || *line == '\n'|| *line == '\t' )
            *line++ = '\0';

        /* Adding next command line argument to `argv` */
        *argv++ = line;

        while (*line != '\0' && *line!= ' ' && *line != '\t' && *line != '\n')
            line++;
    }
    *argv = '\0';
}

Проблема в том, что вы добавляете следующий аргумент командной строки в argv, прежде чем вы на самом деле узнаете, есть ли следующая команда Строковый аргумент. Поэтому мы должны добавить тест до *argv++ = line;. Теперь проверка в операторе while становится ненужной.

void  parsowanie(char *line, char **argv)
{
    while (1) {
        /* Eating whitespace */
        while (*line == ' ' || *line == '\n'|| *line == '\t' )
            *line++ = '\0';

        /* Checking if there are more command line arguments */
        if (!*line)
          {
            /* Terminating `argv` */
            *argv = NULL;
            return;
          }

        /* Adding next command line argument to `argv` */
        *argv++ = line;

        while (*line != '\0' && *line!= ' ' && *line != '\t' && *line != '\n')
            line++;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...