add simple functions for creating lists

23 months ago

author
Mike Becker <universe@uap-core.de>
date
Thu, 23 Feb 2023 22:43:13 +0100 (23 months ago)
changeset 662
d0d95740071b
parent 661
0a71ac9547fd
child 663
d50b5dc1e058

add simple functions for creating lists

src/array_list.c file | annotate | diff | comparison | revisions
src/cx/array_list.h file | annotate | diff | comparison | revisions
src/cx/linked_list.h file | annotate | diff | comparison | revisions
src/linked_list.c file | annotate | diff | comparison | revisions
tests/test_list.cpp file | annotate | diff | comparison | revisions
--- a/src/array_list.c	Thu Feb 23 22:27:41 2023 +0100
+++ b/src/array_list.c	Thu Feb 23 22:43:13 2023 +0100
@@ -460,7 +460,7 @@
         cx_arl_iterator,
 };
 
-CxList *cxArrayListCreate(
+static CxList *cx_array_list_create(
         CxAllocator const *allocator,
         CxListComparator comparator,
         size_t item_size,
@@ -487,3 +487,21 @@
 
     return (CxList *) list;
 }
+
+CxList *cxArrayListCreate(
+        CxAllocator const *allocator,
+        CxListComparator comparator,
+        size_t item_size,
+        size_t initial_capacity
+) {
+    return cx_array_list_create(allocator, comparator,
+                                item_size, initial_capacity);
+}
+
+CxList *cxArrayListCreateSimple(
+        size_t item_size,
+        size_t initial_capacity
+) {
+    return cx_array_list_create(cxDefaultAllocator, NULL,
+                                item_size, initial_capacity);
+}
--- a/src/cx/array_list.h	Thu Feb 23 22:27:41 2023 +0100
+++ b/src/cx/array_list.h	Thu Feb 23 22:43:13 2023 +0100
@@ -165,6 +165,22 @@
         size_t initial_capacity
 ) __attribute__((__nonnull__));
 
+/**
+ * Allocates an array list for storing elements with \p item_size bytes each.
+ *
+ * The list will use the cxDefaultAllocator and \em NO compare function.
+ * If you want to call functions that need a compare function, you have to
+ * set it immediately after creation or use cxArrayListCreate().
+ *
+ * @param item_size the size of each element in bytes
+ * @param initial_capacity the initial number of elements the array can store
+ * @return the created list
+ */
+CxList *cxArrayListCreateSimple(
+        size_t item_size,
+        size_t initial_capacity
+);
+
 
 #ifdef __cplusplus
 } // extern "C"
--- a/src/cx/linked_list.h	Thu Feb 23 22:27:41 2023 +0100
+++ b/src/cx/linked_list.h	Thu Feb 23 22:43:13 2023 +0100
@@ -54,9 +54,6 @@
 /**
  * Allocates a linked list for storing elements with \p item_size bytes each.
  *
- * @remark Elements added to the list are copied, therefore a possible destructor
- * MUST NOT free the memory pointed to by its argument.
- *
  * @param allocator the allocator for allocating the list nodes
  * @param comparator the comparator for the elements
  * @param item_size the size of each element in bytes
@@ -69,6 +66,18 @@
 ) __attribute__((__nonnull__));
 
 /**
+ * Allocates a linked list for storing elements with \p item_size bytes each.
+ *
+ * The list will use cxDefaultAllocator and no comparator function. If you want
+ * to call functions that need a comparator, you must either set one immediately
+ * after list creation or use cxLinkedListCreate().
+ *
+ * @param item_size the size of each element in bytes
+ * @return the created list
+ */
+CxList *cxLinkedListCreateSimple(size_t item_size);
+
+/**
  * Finds the node at a certain index.
  *
  * This function can be used to start at an arbitrary position within the list.
--- a/src/linked_list.c	Thu Feb 23 22:27:41 2023 +0100
+++ b/src/linked_list.c	Thu Feb 23 22:43:13 2023 +0100
@@ -295,7 +295,7 @@
 ) {
     void *sbo[CX_LINKED_LIST_SORT_SBO_SIZE];
     void **sorted = length >= CX_LINKED_LIST_SORT_SBO_SIZE ?
-            malloc(sizeof(void *) * length) : sbo;
+                    malloc(sizeof(void *) * length) : sbo;
     if (sorted == NULL) abort();
     void *rc, *lc;
 
@@ -870,7 +870,7 @@
         cx_ll_iterator,
 };
 
-CxList *cxLinkedListCreate(
+static CxList *cx_linked_list_create(
         CxAllocator const *allocator,
         CxListComparator comparator,
         size_t item_size
@@ -886,3 +886,15 @@
 
     return (CxList *) list;
 }
+
+CxList *cxLinkedListCreate(
+        CxAllocator const *allocator,
+        CxListComparator comparator,
+        size_t item_size
+) {
+    return cx_linked_list_create(allocator, comparator, item_size);
+}
+
+CxList *cxLinkedListCreateSimple(size_t item_size) {
+    return cx_linked_list_create(cxDefaultAllocator, NULL, item_size);
+}
--- a/tests/test_list.cpp	Thu Feb 23 22:27:41 2023 +0100
+++ b/tests/test_list.cpp	Thu Feb 23 22:43:13 2023 +0100
@@ -915,6 +915,15 @@
     verifyCreate(list);
 }
 
+TEST_F(LinkedList, cxLinkedListCreateSimple) {
+    CxList *list = autofree(cxLinkedListCreateSimple(sizeof(int)));
+    ASSERT_NE(list, nullptr);
+    EXPECT_EQ(list->itemsize, sizeof(int));
+    EXPECT_EQ(list->capacity, (size_t) -1);
+    EXPECT_EQ(list->cmpfunc, nullptr);
+    EXPECT_EQ(list->allocator, cxDefaultAllocator);
+}
+
 TEST_F(ArrayList, cxArrayListCreate) {
     CxList *list = autofree(cxArrayListCreate(&testingAllocator, cx_cmp_int, sizeof(int), 8));
     ASSERT_NE(list, nullptr);
@@ -923,6 +932,15 @@
     verifyCreate(list);
 }
 
+TEST_F(ArrayList, cxArrayListCreateSimple) {
+    CxList *list = autofree(cxArrayListCreateSimple(sizeof(int), 8));
+    ASSERT_NE(list, nullptr);
+    EXPECT_EQ(list->cmpfunc, nullptr);
+    EXPECT_EQ(list->allocator, cxDefaultAllocator);
+    EXPECT_EQ(list->itemsize, sizeof(int));
+    EXPECT_EQ(list->capacity, 8);
+}
+
 TEST_F(LinkedList, cxListAdd) {
     auto list = autofree(cxLinkedListCreate(&testingAllocator, cx_cmp_int, sizeof(int)));
     verifyAdd(list, false);

mercurial