%20.png)
Eu criei meu próprio shell no Linux. Ele leva o caminho do arquivo e do comando. Ele opera comandos simples como grep ls etc. Ele usa a chamada de sistema execlp().
por exemplo, /bin/ls ls < este comando é executado corretamente.
ls < este comando não é executado!
Eu só quero saber o que estou fazendo de errado aqui?
#include <iostream>
#include <sys/wait.h>
#include <unistd.h>
#include <string.h>
#include <cstring>
#include <sys/types.h>
using namespace std;
int main (int argc, char * argv[])
{
while (true){
char * input;
string insert;
char * token;
char * parsed[5];
int count=0;
cout<<"My Shell $";
getline(cin,insert);
input= new char [insert.size()+1];
strcpy(input, insert.c_str());
for (int i=0; i<5; i++)
parsed[i]=NULL;
token=strtok(input, " ");
while (token!=NULL)
{
parsed[count] = new char[strlen(token) + 1];
strcpy(parsed[count++],token);
token=strtok(NULL, " ");
}
delete input;
delete token;
pid_t mypid=fork();
if (mypid==0)
{
execlp (parsed[0],parsed[1],parsed[2],parsed[3],parsed[4], (char*) NULL);
}
else if (mypid>0)
{
wait(NULL);
}
} //end of while
}
Responder1
O problema é que está faltando um parâmetro para execlp
; você precisa especificar o comando a ser executado e, em seguida, todos os seus argumentos, incluindo o primeiro argumento, que é o nome do comando:
execlp(parsed[0], parsed[0], parsed[1], parsed[2], parsed[3], parsed[4], (char*) NULL);
O primeiro parsed[0]
é tomado como execlp
parâmetro path
e o segundo é o first arg
, que termina argv[0]
dentro do comando executado.