diff options
Diffstat (limited to 'src/free_node.c')
| -rw-r--r-- | src/free_node.c | 41 |
1 files changed, 27 insertions, 14 deletions
diff --git a/src/free_node.c b/src/free_node.c index 8f32c12..f387c0a 100644 --- a/src/free_node.c +++ b/src/free_node.c @@ -6,21 +6,19 @@ /* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2024/06/27 11:41:46 by dkaiser #+# #+# */ -/* Updated: 2024/06/28 14:55:50 by dkaiser ### ########.fr */ +/* Updated: 2024/08/02 13:28:47 by dkaiser ### ########.fr */ /* */ /* ************************************************************************** */ #include "ast.h" -static void free_assign_node(t_node *node); static void free_pipe_node(t_node *node); static void free_cmd_node(t_node *node); +static void free_assigns(t_assign **assigns); void free_node(t_node *node) { - if (node->type == ASSIGN_NODE) - free_assign_node(node); - else if (node->type == PIPE_NODE) + if (node->type == PIPE_NODE) free_pipe_node(node); else if (node->type == CMD_NODE) free_cmd_node(node); @@ -31,12 +29,6 @@ void free_node(t_node *node) free(node); } -static void free_assign_node(t_node *node) -{ - free(node->content.assign.var); - free(node->content.assign.value); -} - static void free_pipe_node(t_node *node) { free_node(node->content.pipe.left); @@ -48,12 +40,33 @@ static void free_cmd_node(t_node *node) int i; i = 0; - while (node->content.cmd.args[i] != NULL) + while (node->content.cmd.args != NULL && node->content.cmd.args[i] != NULL) { free(node->content.cmd.args[i]); i++; } free(node->content.cmd.args); - free(node->content.cmd.redirs[0].specifier); - free(node->content.cmd.redirs[1].specifier); + free_assigns(node->content.cmd.assigns); + if (node->content.cmd.redirs[0].type != 0 + && node->content.cmd.redirs[0].specifier != NULL) + free(node->content.cmd.redirs[0].specifier); + if (node->content.cmd.redirs[1].type != 0 + && node->content.cmd.redirs[0].specifier != NULL) + free(node->content.cmd.redirs[1].specifier); +} + +static void free_assigns(t_assign **assigns) +{ + int i; + + i = 0; + if (assigns == 0) + return ; + while (assigns[i] != NULL) + { + free(assigns[i]->var); + free(assigns[i]); + i++; + } + free(assigns); } |
