mirror of
https://codeberg.org/la-chouette/minishell.git
synced 2025-12-06 07:28:09 +01:00
wordlist: add destroy_idx and pop_idx functions
This commit is contained in:
parent
ad5eb4cc34
commit
4116c2d92f
5 changed files with 132 additions and 1 deletions
1
Makefile
1
Makefile
|
|
@ -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 \
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
56
src/parser/wordlist/wordlist_idx.c
Normal file
56
src/parser/wordlist/wordlist_idx.c
Normal 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));
|
||||
}
|
||||
|
|
@ -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
71
tests/test_wordlist_idx.c
Normal 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);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue