|
|
@ -6,7 +6,7 @@ |
|
|
|
/* By: mea <marvin@42.fr> +#+ +:+ +#+ */ |
|
|
|
/* +#+#+#+#+#+ +#+ */ |
|
|
|
/* Created: 2022/05/03 11:48:16 by narnaud #+# #+# */ |
|
|
|
/* Updated: 2022/05/10 09:56:53 by mea ### ########.fr */ |
|
|
|
/* Updated: 2022/05/11 01:15:39 by narnaud@stude ### ########.fr */ |
|
|
|
/* */ |
|
|
|
/* ************************************************************************** */ |
|
|
|
|
|
|
@ -55,25 +55,36 @@ int builtin_call(t_datas *datas, t_command *cmd) |
|
|
|
int piper(t_datas *datas, t_command *cmd) |
|
|
|
{ |
|
|
|
int pip[2]; |
|
|
|
int status; |
|
|
|
pid_t pid; |
|
|
|
int status; |
|
|
|
int exit_code; |
|
|
|
|
|
|
|
if (cmd->fd[1] == 0 && cmd->next && cmd->next->fd[0] == 0) |
|
|
|
if (cmd->ope == PIPE) |
|
|
|
{ |
|
|
|
pipe(pip); |
|
|
|
cmd->fd[1] = pip[1]; |
|
|
|
cmd->next->fd[0] = pip[0]; |
|
|
|
if (!cmd->fd[1]) |
|
|
|
cmd->fd[1] = pip[1]; |
|
|
|
if (!cmd->fd[0]) |
|
|
|
cmd->next->fd[0] = pip[0]; |
|
|
|
} |
|
|
|
pid = caller(datas, cmd); |
|
|
|
if (cmd->fd[1]) |
|
|
|
close(cmd->fd[1]); |
|
|
|
if (cmd->next) |
|
|
|
piper(datas, cmd->next); |
|
|
|
waitpid(pid, &status, 0); |
|
|
|
if (!cmd->next) |
|
|
|
handle_status(datas, status); |
|
|
|
if (cmd->fd[0]) |
|
|
|
close(cmd->fd[0]); |
|
|
|
printf("%s -ope: %d, pid: %d, fdin: %d, fdout: %d\n", cmd->argv[0], cmd->ope, pid, cmd->fd[0], cmd->fd[1]); |
|
|
|
if (cmd->ope == PIPE) |
|
|
|
pid = piper(datas, cmd->next); |
|
|
|
else |
|
|
|
{ |
|
|
|
waitpid(pid, &status, 0); |
|
|
|
exit_code = handle_status(datas, status); |
|
|
|
if (!cmd->next) |
|
|
|
datas->exit_code = exit_code; |
|
|
|
else if (cmd->next && ((cmd->ope == AND && !exit_code) \ |
|
|
|
|| (cmd->ope == OR && exit_code))) |
|
|
|
piper(datas, cmd->next); |
|
|
|
} |
|
|
|
return (1); |
|
|
|
} |
|
|
|
|
|
|
@ -113,9 +124,15 @@ static pid_t caller(t_datas *datas, t_command *cmd) |
|
|
|
if (builtin_call(datas, cmd) == -1) |
|
|
|
{ |
|
|
|
if (cmd->fd[0]) |
|
|
|
{ |
|
|
|
dup2(cmd->fd[0], STDIN_FILENO); |
|
|
|
close(cmd->fd[0]); |
|
|
|
} |
|
|
|
if (cmd->fd[1]) |
|
|
|
{ |
|
|
|
dup2(cmd->fd[1], STDOUT_FILENO); |
|
|
|
close(cmd->fd[1]); |
|
|
|
} |
|
|
|
exe(datas, cmd); |
|
|
|
} |
|
|
|
exit(EXIT_SUCCESS); |
|
|
|