fixed redirections types handling
This commit is contained in:
@ -6,7 +6,7 @@
|
|||||||
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
|
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/03/05 18:15:27 by marde-vr #+# #+# */
|
/* Created: 2024/03/05 18:15:27 by marde-vr #+# #+# */
|
||||||
/* Updated: 2024/04/02 02:13:50 by tomoron ### ########.fr */
|
/* Updated: 2024/04/02 13:28:32 by babonnet ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
void redirect_input(t_msh *msh)
|
void redirect_input(t_msh *msh)
|
||||||
{
|
{
|
||||||
if (/*msh->in_type != PIPE*/ 1)
|
if (msh->in_type != PIPE)
|
||||||
{
|
{
|
||||||
if (dup2(msh->in_fd, 0) < 0)
|
if (dup2(msh->in_fd, 0) < 0)
|
||||||
ft_exit(msh, 1);
|
ft_exit(msh, 1);
|
||||||
@ -52,13 +52,7 @@ void get_in_type(t_msh *msh, t_cmd *tokens)
|
|||||||
cur_token = tokens;
|
cur_token = tokens;
|
||||||
while (cur_token && cur_token->next && cur_token->cmd_type == CMD)
|
while (cur_token && cur_token->next && cur_token->cmd_type == CMD)
|
||||||
cur_token = cur_token->next;
|
cur_token = cur_token->next;
|
||||||
// if (cur_token->type)
|
if (/*cur_token->type && */cur_token->cmd_type == HERE_DOC || cur_token->cmd_type == RED_I)
|
||||||
//{
|
|
||||||
// msh->in_type = cur_token->type;
|
|
||||||
// if (cur_token->type == HERE_DOC || cur_token->type == RED_I)
|
|
||||||
// open_input_file(msh, &cur_token);
|
|
||||||
//} pas sur de ce que c'est censé faire , j'ai fais un truc différent en dessous
|
|
||||||
if (cur_token->cmd_type == HERE_DOC || cur_token->cmd_type == RED_I)
|
|
||||||
{
|
{
|
||||||
msh->in_type = cur_token->cmd_type;
|
msh->in_type = cur_token->cmd_type;
|
||||||
open_input_file(msh, &cur_token);
|
open_input_file(msh, &cur_token);
|
||||||
|
12
srcs/pipe.c
12
srcs/pipe.c
@ -6,7 +6,7 @@
|
|||||||
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
|
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/03/05 18:17:25 by marde-vr #+# #+# */
|
/* Created: 2024/03/05 18:17:25 by marde-vr #+# #+# */
|
||||||
/* Updated: 2024/04/02 02:07:25 by tomoron ### ########.fr */
|
/* Updated: 2024/04/02 13:24:17 by babonnet ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -48,11 +48,11 @@ void execute_command(t_msh *msh, char **cmd_args)
|
|||||||
|
|
||||||
void child(t_msh *msh, char **cmd_args, int i)
|
void child(t_msh *msh, char **cmd_args, int i)
|
||||||
{
|
{
|
||||||
// flemme
|
if ((msh->in_type != CMD && msh->in_type != PAREN && msh->in_type != AND
|
||||||
//if ((msh->in_type != ARG /*&& msh->in_type != PIPE*/)
|
&& msh->in_type != OR && msh->in_type != PIPE)
|
||||||
// || (/*msh->in_type == PIPE &&*/ i > 0))
|
|| (msh->in_type == PIPE && i > 0))
|
||||||
// redirect_input(msh);
|
redirect_input(msh);
|
||||||
if (/*msh->out_type == PIPE ||*/ msh->out_type == RED_O
|
if (msh->out_type == PIPE || msh->out_type == RED_O
|
||||||
|| msh->out_type == RED_O_APP)
|
|| msh->out_type == RED_O_APP)
|
||||||
redirect_output(msh, i);
|
redirect_output(msh, i);
|
||||||
close_pipe_fds(msh, i);
|
close_pipe_fds(msh, i);
|
||||||
|
Reference in New Issue
Block a user