Merge branch 'main' of github.com:mdev9/minishell
This commit is contained in:
12
srcs/exec.c
12
srcs/exec.c
@ -6,7 +6,7 @@
|
|||||||
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
|
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/02/07 14:12:49 by tomoron #+# #+# */
|
/* Created: 2024/02/07 14:12:49 by tomoron #+# #+# */
|
||||||
/* Updated: 2024/02/17 00:08:02 by tomoron ### ########.fr */
|
/* Updated: 2024/02/17 00:26:16 by marde-vr ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -143,7 +143,7 @@ void exec_command(t_cmd *parsed_cmd, t_env *env)
|
|||||||
return ;
|
return ;
|
||||||
cur_cmd = parsed_cmd;
|
cur_cmd = parsed_cmd;
|
||||||
args_count = get_args_count(parsed_cmd);
|
args_count = get_args_count(parsed_cmd);
|
||||||
cmd_args = calloc(args_count + 1, sizeof(char *));
|
cmd_args = ft_calloc(args_count + 1, sizeof(char *));
|
||||||
if (!cmd_args)
|
if (!cmd_args)
|
||||||
ft_exit(parsed_cmd, env, 1);
|
ft_exit(parsed_cmd, env, 1);
|
||||||
i = 0;
|
i = 0;
|
||||||
@ -154,8 +154,6 @@ void exec_command(t_cmd *parsed_cmd, t_env *env)
|
|||||||
cur_cmd = cur_cmd->next;
|
cur_cmd = cur_cmd->next;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
cmd_args[i] = 0;
|
|
||||||
|
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
pid = fork();
|
pid = fork();
|
||||||
if (pid == -1)
|
if (pid == -1)
|
||||||
@ -164,11 +162,17 @@ void exec_command(t_cmd *parsed_cmd, t_env *env)
|
|||||||
ft_exit(parsed_cmd, env, 1);
|
ft_exit(parsed_cmd, env, 1);
|
||||||
}
|
}
|
||||||
if (pid == 0)
|
if (pid == 0)
|
||||||
|
{
|
||||||
|
if (parsed_cmd->token)
|
||||||
execve(parsed_cmd->token, cmd_args, env_to_char_tab(env));
|
execve(parsed_cmd->token, cmd_args, env_to_char_tab(env));
|
||||||
|
ft_exit(parsed_cmd, env, 1);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
rl_redisplay();
|
rl_redisplay();
|
||||||
if (waitpid(pid, 0, 0) < 0)
|
if (waitpid(pid, 0, 0) < 0)
|
||||||
ft_exit(parsed_cmd, env, 1);
|
ft_exit(parsed_cmd, env, 1);
|
||||||
|
}
|
||||||
//if (cur_cmd->type == PIPE)
|
//if (cur_cmd->type == PIPE)
|
||||||
// exec_command(cur_cmd->next, env);
|
// exec_command(cur_cmd->next, env);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user