free leaks
This commit is contained in:
@@ -3,10 +3,10 @@
|
||||
/* ::: :::::::: */
|
||||
/* free_ast.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: nalebrun <nalebrun@student.s19.be> +#+ +:+ +#+ */
|
||||
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/02/05 14:39:28 by nalebrun #+# #+# */
|
||||
/* Updated: 2025/02/05 14:39:28 by nalebrun ### ########.fr */
|
||||
/* Created: 2025/02/05 14:39:28 by lderidde #+# #+# */
|
||||
/* Updated: 2025/02/07 09:20:16 by lderidde ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -53,3 +53,9 @@ void free_ast(t_ast_n *node)
|
||||
free_cmd(node);
|
||||
free(node);
|
||||
}
|
||||
|
||||
void free_child(t_msh *msh)
|
||||
{
|
||||
free_ast(msh->head);
|
||||
free_msh(msh);
|
||||
}
|
||||
|
||||
@@ -3,10 +3,10 @@
|
||||
/* ::: :::::::: */
|
||||
/* subsh.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: nalebrun <nalebrun@student.s19.be> +#+ +:+ +#+ */
|
||||
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/02/05 07:51:27 by nalebrun #+# #+# */
|
||||
/* Updated: 2025/02/05 07:51:27 by nalebrun ### ########.fr */
|
||||
/* Created: 2025/02/05 07:51:27 by lderidde #+# #+# */
|
||||
/* Updated: 2025/02/07 09:12:41 by lderidde ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -17,6 +17,7 @@ t_node *remove_parentheses(t_node *lst)
|
||||
t_node *it;
|
||||
t_node *out;
|
||||
int deepness;
|
||||
char *str;
|
||||
|
||||
out = NULL;
|
||||
it = lst;
|
||||
@@ -24,15 +25,18 @@ t_node *remove_parentheses(t_node *lst)
|
||||
deepness = 1;
|
||||
while (1)
|
||||
{
|
||||
str = ft_strdup(it->val);
|
||||
if (it->pressision == SUBSH_S)
|
||||
deepness += 1;
|
||||
if (it->pressision == SUBSH_E)
|
||||
deepness -= 1;
|
||||
if (deepness == 0)
|
||||
break;
|
||||
add_node_back(&out, ft_strdup(it->val), it->token, it->pressision);
|
||||
add_node_back(&out, str, it->token, it->pressision);
|
||||
free(str);
|
||||
it = it->next;
|
||||
}
|
||||
free(str);
|
||||
return (out);
|
||||
}
|
||||
|
||||
|
||||
@@ -3,10 +3,10 @@
|
||||
/* ::: :::::::: */
|
||||
/* drawio_ast.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: nalebrun <nalebrun@student.s19.be> +#+ +:+ +#+ */
|
||||
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/01/27 17:15:39 by nalebrun #+# #+# */
|
||||
/* Updated: 2025/01/27 17:15:39 by nalebrun ### ########.fr */
|
||||
/* Created: 2025/01/27 17:15:39 by lderidde #+# #+# */
|
||||
/* Updated: 2025/02/07 09:14:08 by lderidde ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -24,12 +24,15 @@ void set_ast_rect(t_dio_elem *rect)
|
||||
|
||||
void gen_dio_ast(t_ast_n *head, int fd)
|
||||
{
|
||||
t_elems e;
|
||||
t_elems *e;
|
||||
|
||||
set_ast_rect(&e.rect);
|
||||
e.arrow.type = ARROW;
|
||||
e.arrow.id_src = 0;
|
||||
e.arrow.id_dst = 0;
|
||||
print_ast(head, &e, fd);
|
||||
e = ft_calloc(sizeof(t_elems), 1);
|
||||
set_ast_rect(&e->rect);
|
||||
e->arrow.type = ARROW;
|
||||
e->arrow.id_src = 0;
|
||||
e->arrow.id_dst = 0;
|
||||
print_ast(head, e, fd);
|
||||
free(e->rect.text);
|
||||
free(e);
|
||||
return ;
|
||||
}
|
||||
|
||||
@@ -3,10 +3,10 @@
|
||||
/* ::: :::::::: */
|
||||
/* drawio_print_ast.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: nalebrun <nalebrun@student.s19.be> +#+ +:+ +#+ */
|
||||
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/01/29 09:54:31 by nalebrun #+# #+# */
|
||||
/* Updated: 2025/01/29 09:54:31 by nalebrun ### ########.fr */
|
||||
/* Created: 2025/01/29 09:54:31 by lderidde #+# #+# */
|
||||
/* Updated: 2025/02/07 09:09:01 by lderidde ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -20,14 +20,15 @@ char *get_node_txt(t_ast_n *node)
|
||||
|
||||
txt = get_cmd_txt(node);
|
||||
if (node->sh == true)
|
||||
subsh = " (subsh) ";
|
||||
subsh = ft_strdup(" (subsh) ");
|
||||
else
|
||||
subsh = "";
|
||||
subsh = ft_strdup("");
|
||||
out = ft_sprintf("%s%s%s%s%s", txt.st, txt.cmd, txt.args,
|
||||
subsh, txt.files);
|
||||
free(txt.cmd);
|
||||
free(txt.args);
|
||||
free(txt.files);
|
||||
free(subsh);
|
||||
return (out);
|
||||
}
|
||||
|
||||
@@ -67,12 +68,12 @@ int print_ast(t_ast_n *node, t_elems *e, int fd)
|
||||
|
||||
if (!node)
|
||||
return (-1);
|
||||
ft_free(&e->rect.text);
|
||||
e->rect.text = get_node_txt(node);
|
||||
node_id = drawio_create_elem(fd, &e->rect);
|
||||
if (node->state != _PLINE)
|
||||
draw_bin_part(node, e, fd, node_id);
|
||||
else
|
||||
draw_pline_part(node, e, fd, node_id);
|
||||
ft_free(&e->rect.text);
|
||||
return (node_id);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user