leaks removing still some left
This commit is contained in:
@@ -13,7 +13,7 @@
|
|||||||
#ifndef MINISHELL_H
|
#ifndef MINISHELL_H
|
||||||
# define MINISHELL_H
|
# define MINISHELL_H
|
||||||
|
|
||||||
# define DEBUG 0
|
# define DEBUG 1
|
||||||
|
|
||||||
typedef struct s_ast_n t_ast_n;
|
typedef struct s_ast_n t_ast_n;
|
||||||
typedef struct s_node t_node;
|
typedef struct s_node t_node;
|
||||||
@@ -41,6 +41,8 @@ typedef struct s_msh
|
|||||||
# include "exec/env.h"
|
# include "exec/env.h"
|
||||||
# include "exec/exec.h"
|
# include "exec/exec.h"
|
||||||
|
|
||||||
|
t_msh *init_msh(char **envp);
|
||||||
|
void free_msh(t_msh *msh);
|
||||||
|
|
||||||
# define POW1 "\033[1;38;2;21;22;26;48;2;92;106;178m"
|
# define POW1 "\033[1;38;2;21;22;26;48;2;92;106;178m"
|
||||||
# define POW2 "\033[1;38;2;92;106;178;48;2;54;54;54m"
|
# define POW2 "\033[1;38;2;92;106;178;48;2;54;54;54m"
|
||||||
|
|||||||
34
srcs/main.c
34
srcs/main.c
@@ -12,7 +12,7 @@
|
|||||||
|
|
||||||
#include "../includes/minishell.h"
|
#include "../includes/minishell.h"
|
||||||
|
|
||||||
char *powerline(void)
|
static char *powerline(void)
|
||||||
{
|
{
|
||||||
char *pwd;
|
char *pwd;
|
||||||
char *tilt;
|
char *tilt;
|
||||||
@@ -40,36 +40,7 @@ char *powerline(void)
|
|||||||
return (input);
|
return (input);
|
||||||
}
|
}
|
||||||
|
|
||||||
char **ft_setnewenv(void)
|
static void interpret_cmd(char **input, t_msh *msh)
|
||||||
{
|
|
||||||
char **envp;
|
|
||||||
|
|
||||||
envp = malloc(sizeof(char *) * 2);
|
|
||||||
if (!envp)
|
|
||||||
return (NULL);
|
|
||||||
envp[0] = ft_strjoin("PWD=", getcwd(NULL, 0));
|
|
||||||
envp[1] = ft_strdup("SHLVL=1");
|
|
||||||
if (!envp[0] || !envp[1])
|
|
||||||
return (ft_free(&envp[0]), ft_free(&envp[1]), NULL);
|
|
||||||
return (envp);
|
|
||||||
}
|
|
||||||
|
|
||||||
t_msh *init_msh(char **envp)
|
|
||||||
{
|
|
||||||
t_msh *msh;
|
|
||||||
|
|
||||||
msh = malloc(sizeof(t_msh) * 1);
|
|
||||||
msh->ex_code = 0;
|
|
||||||
if (!msh)
|
|
||||||
return (NULL);
|
|
||||||
if (!envp[0])
|
|
||||||
msh->env = ft_setnewenv();
|
|
||||||
else
|
|
||||||
msh->env = init_env(envp);
|
|
||||||
return (msh);
|
|
||||||
}
|
|
||||||
|
|
||||||
void interpret_cmd(char **input, t_msh *msh)
|
|
||||||
{
|
{
|
||||||
msh->head = parser(*input, msh);
|
msh->head = parser(*input, msh);
|
||||||
msh->ex_code = execute_command(msh->head);
|
msh->ex_code = execute_command(msh->head);
|
||||||
@@ -102,4 +73,5 @@ int main(int ac, char **av, char **envp)
|
|||||||
input = ft_strdup(av[1]);
|
input = ft_strdup(av[1]);
|
||||||
interpret_cmd(&input, msh);
|
interpret_cmd(&input, msh);
|
||||||
}
|
}
|
||||||
|
free_msh(msh);
|
||||||
}
|
}
|
||||||
|
|||||||
48
srcs/msh_struct.c
Normal file
48
srcs/msh_struct.c
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
/* ************************************************************************** */
|
||||||
|
/* */
|
||||||
|
/* ::: :::::::: */
|
||||||
|
/* msh_struct.c :+: :+: :+: */
|
||||||
|
/* +:+ +:+ +:+ */
|
||||||
|
/* By: nalebrun <nalebrun@student.s19.be> +#+ +:+ +#+ */
|
||||||
|
/* +#+#+#+#+#+ +#+ */
|
||||||
|
/* Created: 2025/02/06 15:32:03 by nalebrun #+# #+# */
|
||||||
|
/* Updated: 2025/02/06 15:32:03 by nalebrun ### ########.fr */
|
||||||
|
/* */
|
||||||
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
#include "../includes/minishell.h"
|
||||||
|
|
||||||
|
static char **ft_setnewenv(void)
|
||||||
|
{
|
||||||
|
char **envp;
|
||||||
|
|
||||||
|
envp = malloc(sizeof(char *) * 2);
|
||||||
|
if (!envp)
|
||||||
|
return (NULL);
|
||||||
|
envp[0] = ft_strjoin("PWD=", getcwd(NULL, 0));
|
||||||
|
envp[1] = ft_strdup("SHLVL=1");
|
||||||
|
if (!envp[0] || !envp[1])
|
||||||
|
return (ft_free(&envp[0]), ft_free(&envp[1]), NULL);
|
||||||
|
return (envp);
|
||||||
|
}
|
||||||
|
|
||||||
|
t_msh *init_msh(char **envp)
|
||||||
|
{
|
||||||
|
t_msh *msh;
|
||||||
|
|
||||||
|
msh = malloc(sizeof(t_msh) * 1);
|
||||||
|
msh->ex_code = 0;
|
||||||
|
if (!msh)
|
||||||
|
return (NULL);
|
||||||
|
if (!envp[0])
|
||||||
|
msh->env = ft_setnewenv();
|
||||||
|
else
|
||||||
|
msh->env = init_env(envp);
|
||||||
|
return (msh);
|
||||||
|
}
|
||||||
|
|
||||||
|
void free_msh(t_msh *msh)
|
||||||
|
{
|
||||||
|
free_tab(msh->env);
|
||||||
|
free(msh);
|
||||||
|
}
|
||||||
@@ -75,9 +75,13 @@ t_nodell *cutll(t_node *lst, t_node *expected, size_t limiter)
|
|||||||
|
|
||||||
void free_lltab(t_nodell *nodell)
|
void free_lltab(t_nodell *nodell)
|
||||||
{
|
{
|
||||||
|
t_nodell *tmp;
|
||||||
|
|
||||||
while (nodell)
|
while (nodell)
|
||||||
{
|
{
|
||||||
free_linked_list(nodell->node);
|
free_linked_list(nodell->node);
|
||||||
nodell = nodell->next;
|
tmp = nodell->next;
|
||||||
|
free(nodell);
|
||||||
|
nodell = tmp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,5 +54,5 @@ void create_subsh(t_ast_n *self, t_node *lst, t_msh *msh)
|
|||||||
ft_debug("subsh_redir : [%d]%s\n", self->redir[i], self->files[i]);
|
ft_debug("subsh_redir : [%d]%s\n", self->redir[i], self->files[i]);
|
||||||
ft_debug("==== SUBSH DONE\n\n");
|
ft_debug("==== SUBSH DONE\n\n");
|
||||||
|
|
||||||
// free(cutted);
|
free_linked_list(cutted);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -73,5 +73,6 @@ int print_ast(t_ast_n *node, t_elems *e, int fd)
|
|||||||
draw_bin_part(node, e, fd, node_id);
|
draw_bin_part(node, e, fd, node_id);
|
||||||
else
|
else
|
||||||
draw_pline_part(node, e, fd, node_id);
|
draw_pline_part(node, e, fd, node_id);
|
||||||
|
ft_free(&e->rect.text);
|
||||||
return (node_id);
|
return (node_id);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user