🔨」 fix(builtins/ft_exit): fixed leaks :D

This commit is contained in:
yosyo
2024-07-15 15:52:56 +02:00
parent 9a5ff21103
commit de3b52d9d4
4 changed files with 22 additions and 9 deletions

View File

@ -6,7 +6,7 @@
/* By: mmoussou <mmoussou@student.42angouleme.fr +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/22 13:05:18 by adjoly #+# #+# */
/* Updated: 2024/07/15 13:29:21 by mmoussou ### ########.fr */
/* Updated: 2024/07/15 15:48:38 by mmoussou ### ########.fr */
/* */
/* ************************************************************************** */
@ -29,7 +29,8 @@ void ft_env(t_env *env);
void ft_unset(char *arg, t_env *env);
void ft_exit(char **argv, int ac);
void free_exit(t_env *env, char **env_array);
void ft_exit(char **argv, int ac, char **env_array, t_env *env);
char **env_get_list(t_env *env);
void add_to_env(char *name, char *content, t_env *env);

View File

@ -3,19 +3,28 @@
/* ::: :::::::: */
/* free_exit.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* By: mmoussou <mmoussou@student.42angouleme.fr +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/07/15 12:28:36 by adjoly #+# #+# */
/* Updated: 2024/07/15 15:27:45 by adjoly ### ########.fr */
/* Updated: 2024/07/15 15:50:55 by mmoussou ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
#include "parsing.h"
void free_exit(t_env *env)
void free_exit(t_env *env, char **env_array)
{
int i;
i = 0;
while (i < 1024)
{
close(i);
i++;
}
rl_clear_history();
ft_envclear(&env, free);
ft_lstclear(get_list(NULL), &free_cmd);
ft_free("a", &env_array);
}

View File

@ -6,11 +6,12 @@
/* By: mmoussou <mmoussou@student.42angouleme.fr +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/07/14 13:46:57 by adjoly #+# #+# */
/* Updated: 2024/07/15 15:14:57 by mmoussou ### ########.fr */
/* Updated: 2024/07/15 15:49:06 by mmoussou ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
#include "builtins.h"
int check_exit_value(char *str)
{
@ -30,7 +31,7 @@ int check_exit_value(char *str)
return (0);
}
void ft_exit(char **argv, int ac)
void ft_exit(char **argv, int ac, char **env_array, t_env *env)
{
int return_value;
@ -39,6 +40,7 @@ void ft_exit(char **argv, int ac)
if (check_exit_value(argv[1]))
{
printf("minishell: exit: %s: numeric argument required\n", argv[1]);
free_exit(env, env_array);
exit(2);
}
else
@ -50,6 +52,7 @@ void ft_exit(char **argv, int ac)
return_value = atoi(argv[1]);
if (return_value == -1)
return_value += 255;
free_exit(env, env_array);
exit(get_exit_code(return_value));
}
}

View File

@ -6,7 +6,7 @@
/* By: mmoussou <mmoussou@student.42angouleme.fr +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/01 14:55:06 by mmoussou #+# #+# */
/* Updated: 2024/07/15 15:23:24 by adjoly ### ########.fr */
/* Updated: 2024/07/15 15:47:01 by mmoussou ### ########.fr */
/* */
/* ************************************************************************** */
@ -37,7 +37,7 @@ void exec_cmd(char *cmd, char **argv, char **env, t_env *env_t)
if (i == 7)
ft_env(env_t);
if (i == 1)
ft_exit(argv, ft_arrlen(argv));
ft_exit(argv, ft_arrlen(argv), env, env_t);
}
else
execve(cmd, argv, env);