aboutsummaryrefslogtreecommitdiff
path: root/src/free_token.c
diff options
context:
space:
mode:
authorDominik Kaiser2025-01-25 15:58:12 +0100
committerGitHub2025-01-25 15:58:12 +0100
commit3b97eaa0500314866c4a106c77e8f671c9751b89 (patch)
treef44fffea0ef290f9bdf79448c90d794ba97b8ca4 /src/free_token.c
parentbd8c817797d5f2b1affe6957ffc51846a38e70ec (diff)
parent8fb5e2839cb7eb7bb72f577577afafcdbdc8a714 (diff)
downloadminishell-3b97eaa0500314866c4a106c77e8f671c9751b89.tar.gz
minishell-3b97eaa0500314866c4a106c77e8f671c9751b89.zip
Merge memory leak fixes
Diffstat (limited to 'src/free_token.c')
-rw-r--r--src/free_token.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/src/free_token.c b/src/free_token.c
index 512ba23..a63e750 100644
--- a/src/free_token.c
+++ b/src/free_token.c
@@ -6,7 +6,7 @@
/* By: chuhlig <chuhlig@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/27 14:38:57 by dkaiser #+# #+# */
-/* Updated: 2025/01/20 12:49:48 by chuhlig ### ########.fr */
+/* Updated: 2025/01/25 11:36:59 by chuhlig ### ########.fr */
/* */
/* ************************************************************************** */
@@ -23,6 +23,18 @@ void free_token(t_token *token)
token = NULL;
}
+void free_token2(t_token *token)
+{
+ if (token->previous != NULL)
+ token->previous->next = NULL;
+ if (token->next != NULL)
+ token->next->previous = NULL;
+ if (token->type == STRING_TOKEN && token->content.string != NULL)
+ free(token->content.string);
+ free(token);
+ token = NULL;
+}
+
void free_token_and_connect(t_token *token)
{
if (token->previous != NULL)
@@ -33,12 +45,24 @@ void free_token_and_connect(t_token *token)
token = NULL;
}
+void free_token_and_connect2(t_token *token)
+{
+ if (token->previous != NULL)
+ token->previous->next = token->next;
+ if (token->next != NULL)
+ token->next->previous = token->previous;
+ if (token->type == STRING_TOKEN && token->content.string != NULL)
+ free(token->content.string);
+ free(token);
+ token = NULL;
+}
+
void free_tokens(t_token *tokens)
{
while (tokens->next != NULL)
{
tokens = tokens->next;
- free_token(tokens->previous);
+ free_token2(tokens->previous);
}
- free_token(tokens);
+ free_token2(tokens);
}