Вопрос

Я пишу мини-оболочку, чтобы лучше познакомиться с управлением процессами в Unix на C. Он читает информацию из командной строки и передает эти аргументы через execlp в систему.

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

#define MAXSIZE 100

char prompt[MAXSIZE];

int main(void)
{
   pid_t pid;

   printf("> ");

   // read stuff 
   if (fgets(prompt, MAXSIZE, stdin) == NULL){
      printf("Input validation error!");
      abort();
   }
   // printf("DEBUG: %s" , prompt);

   if (strcmp(prompt, "exit")==0) abort();


   if ((pid=fork())<0){       // copy process

      printf("Process error!");
      abort();
   }

   if (pid==0){                // exec in son-prcess

      char *command=(char*)strtok(prompt, " ");
      execlp(command, command, 0);  // overwrite memory

      printf("Error, command not found!");
      abort();
   } else {

      waitpid(pid, 0, 0);
    }
}

На самом деле это так, но я не получаю вывод от execlp () . Кто-нибудь знает, почему это так?

Это было полезно?

Решение

Я попытался запустить вашу программу, но она не удалась, потому что команда содержала \ n (перевод строки). Я изменил его, поставив \ n вместо " & Quot; в strtok , и затем он успешно запустился.

Подробно:

  if (pid==0){                // exec in son-prcess
      char *command=(char*)strtok(prompt, "\n");
      printf ("'%s'\n", command);
      execlp (command, command, 0);  // overwrite memory
      printf("Error %d (%s)\n", errno, strerror (errno));
      abort();
   } else {

Тестовый прогон:

$ ./a.out 
> ls
'ls'
(usual ls behaviour)

Другие советы

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

printf("Error, command not found!\n");
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top