Domanda

Sto scrivendo una mini-shell per acquisire maggiore familiarità con la gestione dei processi Unix in C. Sta leggendo cose dalla riga di comando e passa questi argomenti tramite execlp al sistema.

# 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);
    }
}

In realtà sarebbe così, ma non ottengo alcun output da execlp () . Qualcuno sa perché?

È stato utile?

Soluzione

Ho provato a eseguire il programma e non è riuscito perché comando conteneva un \ n (newline). L'ho modificato inserendo \ n anziché " & Quot; nel strtok e quindi ha funzionato correttamente.

Nel dettaglio:

  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 {

Esecuzione del test:

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

Altri suggerimenti

Kinopiko ha già scoperto perché non funziona, ma il motivo per cui non è stato visualizzato alcun messaggio di errore è che il prompt della shell lo sta sovrascrivendo. Prova a mettere una nuova riga alla fine:

printf("Error, command not found!\n");
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top