From fb1efe264854e2539d62da1d9dc019ffa8a899da Mon Sep 17 00:00:00 2001 From: Alessandro Iezzi Date: Wed, 17 May 2023 16:51:48 +0200 Subject: Divide in two functions the clist_add In some cases, I need to retrieve the original pointer in list_item. So, the clist_add() just adds the pointer to the list, and, clist_add_s() adds a copy of that pointer to the list. --- src/list.c | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) (limited to 'src/list.c') diff --git a/src/list.c b/src/list.c index 01a6822..38957e8 100644 --- a/src/list.c +++ b/src/list.c @@ -18,15 +18,11 @@ clist_create() void clist_add(list_t *list, - void *data, - size_t data_s) + void *data) { struct list_item_t *item = malloc(sizeof(struct list_item_t)); - void *dest = malloc(data_s); /* allocates memory like data parameter */ - memcpy(dest, data, data_s); /* copies data inside dest */ - item->data = dest; - item->data_s = data_s; + item->data = data; item->next = NULL; if (list->first == NULL) @@ -39,6 +35,19 @@ clist_add(list_t *list, list->size ++; } +void +clist_add_s(list_t *list, + void *data, + size_t data_s) +{ + void *dest = malloc(data_s); /* allocates memory like data parameter */ + memcpy(dest, data, data_s); /* copies data inside dest */ + + clist_add(list, dest); + + list->last->data_s = data_s; +} + void clist_add_all(list_t *dest, list_t *other) { @@ -48,7 +57,7 @@ void clist_add_all(list_t *dest, iterator_t i = clist_iterator(other); while (clist_iterator_has_next(i)) { list_item_t *item = clist_iterator_next_item(&i); - clist_add(dest, item->data, item->data_s); + clist_add_s(dest, item->data, item->data_s); } } -- cgit v1.2.3