wordlist: add destroy_idx and pop_idx functions

This commit is contained in:
Khaïs COLIN 2025-03-10 14:22:58 +01:00
parent ad5eb4cc34
commit 4116c2d92f
Signed by: logistic-bot
SSH key fingerprint: SHA256:RlpiqKeXpcPFZZ4y9Ou4xi2M8OhRJovIwDlbCaMsuAo
5 changed files with 132 additions and 1 deletions

View file

@ -45,6 +45,7 @@ srcs = \
src/parser/wordlist/wordlist.c \
src/parser/wordlist/wordlist_copy.c \
src/parser/wordlist/wordlist_debug.c \
src/parser/wordlist/wordlist_idx.c \
src/parser/wordsplit/rule_utils.c \
src/parser/wordsplit/tokenizing_1_5.c \
src/parser/wordsplit/tokenizing_6_10.c \

View file

@ -6,7 +6,7 @@
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/02/13 15:46:02 by khais #+# #+# */
/* Updated: 2025/03/10 14:26:47 by khais ### ########.fr */
/* Updated: 2025/03/10 14:27:27 by khais ### ########.fr */
/* */
/* ************************************************************************** */
@ -41,5 +41,7 @@ t_wordlist *wordlist_push(t_wordlist *wordlist, t_worddesc *worddesc);
t_worddesc *wordlist_pop(t_wordlist **wordlist);
void wordlist_debug(t_wordlist *wordlist);
t_wordlist *wordlist_copy(const t_wordlist *wordlist);
void wordlist_destroy_idx(t_wordlist **wordlist, int idx);
t_worddesc *wordlist_pop_idx(t_wordlist **wordlist, int idx);
#endif

View file

@ -0,0 +1,56 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* wordlist_idx.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/03/09 15:14:27 by khais #+# #+# */
/* Updated: 2025/03/10 16:08:43 by khais ### ########.fr */
/* */
/* ************************************************************************** */
#include "wordlist.h"
#include <stdlib.h>
/*
** Remove the element at the given index from the wordlist and return it.
**
** return null if out of range or wordlist is null
*/
t_worddesc *wordlist_pop_idx(t_wordlist **wordlist, int idx)
{
t_wordlist *iter;
t_wordlist *temp;
t_worddesc *out;
if (wordlist == NULL || *wordlist == NULL || idx < 0)
return (NULL);
iter = *wordlist;
if (idx == 0)
{
*wordlist = (*wordlist)->next;
out = iter->word;
return (free(iter), out);
}
while (idx-- > 1)
{
iter = iter->next;
if (iter == NULL)
return (NULL);
}
temp = iter->next;
if (temp == NULL)
return (NULL);
out = temp->word;
iter->next = temp->next;
return (free(temp), out);
}
/*
** Remove the element at the given index from the wordlist and destroy it.
*/
void wordlist_destroy_idx(t_wordlist **wordlist, int idx)
{
worddesc_destroy(wordlist_pop_idx(wordlist, idx));
}

View file

@ -1,6 +1,7 @@
# make gets confused if a file with the same name exists in the sources, so some
# file are prefixed with test_
rawtests = \
test_wordlist_idx \
test_redirection_parsing \
quote_removal \
cmdlist_use_after_free \

71
tests/test_wordlist_idx.c Normal file
View file

@ -0,0 +1,71 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* test_wordlist_idx.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/03/10 14:59:19 by khais #+# #+# */
/* Updated: 2025/03/10 16:02:01 by khais ### ########.fr */
/* */
/* ************************************************************************** */
#include "testutil.h"
#include "libft.h"
#include "../src/parser/wordlist/wordlist.h"
#include <assert.h>
static void test_wordlist_idx_pop_null(void)
{
t_wordlist *list;
ft_dprintf(STDERR_FILENO, "==> %s <==\n", __FUNCTION__);
assert(NULL == wordlist_pop_idx(NULL, 10));
list = NULL;
assert(NULL == wordlist_pop_idx(&list, 10));
do_leak_check();
}
static void test_wordlist_idx_pop_single_elem(void)
{
t_wordlist *list;
t_worddesc *got;
ft_dprintf(STDERR_FILENO, "==> %s <==\n", __FUNCTION__);
list = wordlist_create(worddesc_create(ft_strdup("hello"), 0, ft_strdup("")));
assert(NULL == wordlist_pop_idx(&list, 1));
got = wordlist_pop_idx(&list, 0);
assert(NULL != got);
assert(NULL == list);
assert_strequal("hello", got->word);
assert(NULL == wordlist_pop_idx(&list, 0));
do_leak_check();
}
static void test_wordlist_idx_pop_second_then_first(void)
{
t_wordlist *list;
t_worddesc *got;
ft_dprintf(STDERR_FILENO, "==> %s <==\n", __FUNCTION__);
list = wordlist_create(worddesc_create(ft_strdup("hello"), 0, NULL));
list = wordlist_push(list, worddesc_create(ft_strdup("world"), 0, NULL));
wordlist_debug(list);
got = wordlist_pop_idx(&list, 1);
assert(NULL != got);
assert(NULL != list);
assert_strequal("world", got->word);
got = wordlist_pop_idx(&list, 0);
assert(NULL != got);
assert(NULL == list);
assert_strequal("hello", got->word);
do_leak_check();
}
int main(void)
{
test_wordlist_idx_pop_null();
test_wordlist_idx_pop_single_elem();
test_wordlist_idx_pop_second_then_first();
return (0);
}