Sun, 23 Nov 2025 13:15:19 +0100
optimize sorted insertion by using the infimum instead of the supremum
The reason is that the supremum returns the equal element with the smallest index, and we want the largest.
Therefore, we use the infimum, which already gives us the largest index when there are equal elements, and increase the index by one. The infimum is also guaranteed to exist in that case.
| 390 | 1 | /* |
| 2 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. | |
| 3 | * | |
| 4 | * Copyright 2021 Mike Becker, Olaf Wintermann All rights reserved. | |
| 5 | * | |
| 6 | * Redistribution and use in source and binary forms, with or without | |
| 7 | * modification, are permitted provided that the following conditions are met: | |
| 8 | * | |
| 9 | * 1. Redistributions of source code must retain the above copyright | |
| 10 | * notice, this list of conditions and the following disclaimer. | |
| 11 | * | |
| 12 | * 2. Redistributions in binary form must reproduce the above copyright | |
| 13 | * notice, this list of conditions and the following disclaimer in the | |
| 14 | * documentation and/or other materials provided with the distribution. | |
| 15 | * | |
| 16 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |
| 17 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
| 18 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
| 19 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE | |
| 20 | * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | |
| 21 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | |
| 22 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | |
| 23 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | |
| 24 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | |
| 25 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |
| 26 | * POSSIBILITY OF SUCH DAMAGE. | |
| 27 | */ | |
|
453
bb144d08cd44
add some documentation and changes some signatures
Mike Becker <universe@uap-core.de>
parents:
439
diff
changeset
|
28 | /** |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
29 | * @file list.h |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
30 | * @brief Interface for list implementations. |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
31 | * @author Mike Becker |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
32 | * @author Olaf Wintermann |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
33 | * @copyright 2-Clause BSD License |
|
453
bb144d08cd44
add some documentation and changes some signatures
Mike Becker <universe@uap-core.de>
parents:
439
diff
changeset
|
34 | */ |
| 390 | 35 | |
| 36 | #ifndef UCX_LIST_H | |
| 37 | #define UCX_LIST_H | |
| 38 | ||
|
681
502105523db7
fix common.h include problems - fixes #255
Mike Becker <universe@uap-core.de>
parents:
677
diff
changeset
|
39 | #include "common.h" |
|
677
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
40 | #include "collection.h" |
|
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
41 | |
| 416 | 42 | #ifdef __cplusplus |
| 43 | extern "C" { | |
| 44 | #endif | |
| 45 | ||
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
46 | /** |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
47 | * List class type. |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
48 | */ |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
49 | typedef struct cx_list_class_s cx_list_class; |
|
435
0fe204d50f54
change inheritance model for lists
Mike Becker <universe@uap-core.de>
parents:
416
diff
changeset
|
50 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
51 | /** |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
52 | * Structure for holding the base data of a list. |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
53 | */ |
|
435
0fe204d50f54
change inheritance model for lists
Mike Becker <universe@uap-core.de>
parents:
416
diff
changeset
|
54 | struct cx_list_s { |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
55 | /** |
|
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
56 | * Common members for collections. |
|
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
57 | */ |
|
854
fe0d69d72bcd
fix members inherited by macro or include are not documented
Mike Becker <universe@uap-core.de>
parents:
853
diff
changeset
|
58 | CX_COLLECTION_BASE; |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
59 | /** |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
60 | * The list class definition. |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
61 | */ |
|
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
62 | const cx_list_class *cl; |
|
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
63 | /** |
|
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
64 | * The actual implementation in case the list class is delegating. |
|
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
65 | */ |
|
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
66 | const cx_list_class *climpl; |
|
435
0fe204d50f54
change inheritance model for lists
Mike Becker <universe@uap-core.de>
parents:
416
diff
changeset
|
67 | }; |
|
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
68 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
69 | /** |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
70 | * The class definition for arbitrary lists. |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
71 | */ |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
72 | struct cx_list_class_s { |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
73 | /** |
| 524 | 74 | * Destructor function. |
|
708
1caed6c9ba68
fix inconsistent destructor requirements for list and map classes
Mike Becker <universe@uap-core.de>
parents:
704
diff
changeset
|
75 | * |
|
1caed6c9ba68
fix inconsistent destructor requirements for list and map classes
Mike Becker <universe@uap-core.de>
parents:
704
diff
changeset
|
76 | * Implementations SHALL invoke the content destructor functions if provided |
|
993
b642eca4b956
make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
77 | * and SHALL deallocate the entire list memory. |
| 524 | 78 | */ |
|
993
b642eca4b956
make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
79 | void (*deallocate)(struct cx_list_s *list); |
| 524 | 80 | |
| 81 | /** | |
|
740
529c35a768f3
fix typo in list.h
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
708
diff
changeset
|
82 | * Member function for inserting a single element. |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
83 | * The data pointer may be @c NULL, in which case the function shall only allocate memory. |
| 1341 | 84 | * Returns a pointer to the allocated memory or @c NULL if allocation fails. |
|
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
85 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
86 | void *(*insert_element)(struct cx_list_s *list, size_t index, const void *data); |
|
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
87 | |
|
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
88 | /** |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
89 | * Member function for inserting multiple elements. |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
90 | * |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
91 | * The data pointer may be @c NULL, in which case the function shall only allocate memory. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
92 | * Returns the number of successfully inserted or allocated elements. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
93 | * |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
94 | * @see cx_list_default_insert_array() |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
95 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
96 | size_t (*insert_array)(struct cx_list_s *list, size_t index, const void *data, size_t n); |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
97 | |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
98 | /** |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
99 | * Member function for inserting sorted elements into a sorted list. |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
100 | * Returns the number of successfully inserted elements. |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
101 | * |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
102 | * @see cx_list_default_insert_sorted() |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
103 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
104 | size_t (*insert_sorted)(struct cx_list_s *list, const void *sorted_data, size_t n); |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
105 | |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
106 | /** |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
107 | * Member function for inserting multiple elements if they do not exist. |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
108 | * Implementations shall return the number of successfully processed elements |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
109 | * (including those which were not added because they are already contained). |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
110 | * @see cx_list_default_insert_unique() |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
111 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
112 | size_t (*insert_unique)(struct cx_list_s *list, const void *sorted_data, size_t n); |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
113 | |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
114 | /** |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
115 | * Member function for inserting an element relative to an iterator position. |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
116 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
117 | int (*insert_iter)(struct cx_iterator_s *iter, const void *elem, int prepend); |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
118 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
119 | /** |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
120 | * Member function for removing elements. |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
121 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
122 | * Implementations SHALL check if @p targetbuf is set and copy the elements |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
123 | * to the buffer without invoking any destructor. |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
124 | * When @p targetbuf is not set, the destructors SHALL be invoked. |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
125 | * |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
126 | * The function SHALL return the actual number of elements removed, which |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
127 | * might be lower than @p num when going out of bounds. |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
128 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
129 | size_t (*remove)(struct cx_list_s *list, size_t index, size_t num, void *targetbuf); |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
130 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
131 | /** |
|
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
132 | * Member function for removing all elements. |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
133 | */ |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
134 | void (*clear)(struct cx_list_s *list); |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
135 | |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
136 | /** |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
137 | * Member function for swapping two elements. |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
138 | * |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
139 | * @see cx_list_default_swap() |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
140 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
141 | int (*swap)(struct cx_list_s *list, size_t i, size_t j); |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
142 | |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
143 | /** |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
144 | * Member function for element lookup. |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
145 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
146 | void *(*at)(const struct cx_list_s *list, size_t index); |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
147 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
148 | /** |
|
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
149 | * Member function for finding and optionally removing an element. |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
150 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
151 | size_t (*find_remove)(struct cx_list_s *list, const void *elem, bool remove); |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
152 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
153 | /** |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
154 | * Member function for sorting the list. |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
155 | * |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
156 | * @see cx_list_default_sort() |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
157 | */ |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
158 | void (*sort)(struct cx_list_s *list); |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
159 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
160 | /** |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
161 | * Optional member function for comparing this list |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
162 | * to another list of the same type. |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
163 | * If set to @c NULL, the comparison won't be optimized. |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
164 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
165 | int (*compare)(const struct cx_list_s *list, const struct cx_list_s *other); |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
166 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
167 | /** |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
168 | * Member function for reversing the order of the items. |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
169 | */ |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
170 | void (*reverse)(struct cx_list_s *list); |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
171 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
172 | /** |
|
1482
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
173 | * Optional member function for changing the capacity. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
174 | * If the list does not support overallocation, this can be set to @c NULL. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
175 | */ |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
176 | int (*change_capacity)(struct cx_list_s *list, size_t new_capacity); |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
177 | |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
178 | /** |
|
640
55cc3b373c5e
simplify list class - fixes #236
Mike Becker <universe@uap-core.de>
parents:
638
diff
changeset
|
179 | * Member function for returning an iterator pointing to the specified index. |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
180 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
181 | struct cx_iterator_s (*iterator)(const struct cx_list_s *list, size_t index, bool backward); |
|
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
182 | }; |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
183 | |
|
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
184 | /** |
|
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
185 | * Common type for all list implementations. |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
186 | */ |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
187 | typedef struct cx_list_s CxList; |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
188 | |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
189 | /** |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
190 | * A shared instance of an empty list. |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
191 | * |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
192 | * Writing to that list is not allowed. |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
193 | * |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
194 | * You can use this as a placeholder for initializing CxList pointers |
|
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
195 | * for which you do not want to reserve memory right from the beginning. |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
196 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
197 | CX_EXPORT extern CxList *const cxEmptyList; |
|
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
198 | |
|
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
199 | /** |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
200 | * Default implementation of an array insert. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
201 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
202 | * This function uses the element insert function for each element of the array. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
203 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
204 | * Use this in your own list class if you do not want to implement an optimized |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
205 | * version for your list. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
206 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
207 | * @param list the list |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
208 | * @param index the index where to insert the data |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
209 | * @param data a pointer to the array of data to insert |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
210 | * @param n the number of elements to insert |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
211 | * @return the number of elements actually inserted |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
212 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
213 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
214 | CX_EXPORT size_t cx_list_default_insert_array(struct cx_list_s *list, |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
215 | size_t index, const void *data, size_t n); |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
216 | |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
217 | /** |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
218 | * Default implementation of a sorted insert. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
219 | * |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
220 | * This function uses the array insert function to insert consecutive groups |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
221 | * of sorted data. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
222 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
223 | * The source data @em must already be sorted wrt. the list's compare function. |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
224 | * |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
225 | * Use this in your own list class if you do not want to implement an optimized |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
226 | * version for your list. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
227 | * |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
228 | * @param list the list |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
229 | * @param sorted_data a pointer to the array of pre-sorted data to insert |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
230 | * @param n the number of elements to insert |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
231 | * @return the number of elements actually inserted |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
232 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
233 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
234 | CX_EXPORT size_t cx_list_default_insert_sorted(struct cx_list_s *list, |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
235 | const void *sorted_data, size_t n); |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
236 | |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
237 | /** |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
238 | * Default implementation of an array insert where only elements are inserted when they don't exist in the list. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
239 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
240 | * This function is similar to cx_list_default_insert_sorted(), except it skips elements that are already in the list. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
241 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
242 | * @note The return value of this function denotes the number of elements from the @p sorted_data that are definitely |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
243 | * contained in the list after completing the call. It is @em not the number of elements that were newly inserted. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
244 | * That means, when no error occurred, the return value should be @p n. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
245 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
246 | * Use this in your own list class if you do not want to implement an optimized version for your list. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
247 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
248 | * @param list the list |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
249 | * @param sorted_data a pointer to the array of pre-sorted data to insert |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
250 | * @param n the number of elements to insert |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
251 | * @return the number of elements from the @p sorted_data that are definitely present in the list after this call |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
252 | */ |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
253 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
254 | CX_EXPORT size_t cx_list_default_insert_unique(struct cx_list_s *list, |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
255 | const void *sorted_data, size_t n); |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
256 | |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
257 | /** |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
258 | * Default unoptimized sort implementation. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
259 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
260 | * This function will copy all data to an array, sort the array with standard |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
261 | * qsort, and then copy the data back to the list memory. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
262 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
263 | * Use this in your own list class if you do not want to implement an optimized |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
264 | * version for your list. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
265 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
266 | * @param list the list that shall be sorted |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
267 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
268 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
269 | CX_EXPORT void cx_list_default_sort(struct cx_list_s *list); |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
270 | |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
271 | /** |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
272 | * Default unoptimized swap implementation. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
273 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
274 | * Use this in your own list class if you do not want to implement an optimized |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
275 | * version for your list. |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
276 | * |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
277 | * @param list the list in which to swap |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
278 | * @param i index of one element |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
279 | * @param j index of the other element |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
280 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
281 | * @retval non-zero when indices are out of bounds or memory |
|
882
f8ca6e6c0d48
add missing documentation for cx_list_default_swap() return value
Mike Becker <universe@uap-core.de>
parents:
876
diff
changeset
|
282 | * allocation for the temporary buffer fails |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
283 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
284 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
285 | CX_EXPORT int cx_list_default_swap(struct cx_list_s *list, size_t i, size_t j); |
|
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
286 | |
|
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
287 | /** |
|
1111
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
288 | * Initializes a list struct. |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
289 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
290 | * Only use this function if you are creating your own list implementation. |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
291 | * The purpose of this function is to be called in the initialization code |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
292 | * of your list to set certain members correctly. |
|
1111
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
293 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
294 | * This is particularly important when you want your list to support |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
295 | * #CX_STORE_POINTERS as @p elem_size. This function will wrap the list |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
296 | * class accordingly and make sure that you can implement your list as if |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
297 | * it was only storing objects, and the wrapper will automatically enable |
|
1111
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
298 | * the feature of storing pointers. |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
299 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
300 | * @par Example |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
301 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
302 | * @code |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
303 | * CxList *myCustomListCreate( |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
304 | * const CxAllocator *allocator, |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
305 | * cx_compare_func comparator, |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
306 | * size_t elem_size |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
307 | * ) { |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
308 | * if (allocator == NULL) { |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
309 | * allocator = cxDefaultAllocator; |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
310 | * } |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
311 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
312 | * MyCustomList *list = cxCalloc(allocator, 1, sizeof(MyCustomList)); |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
313 | * if (list == NULL) return NULL; |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
314 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
315 | * // initialize |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
316 | * cx_list_init((CxList*)list, &my_custom_list_class, |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
317 | * allocator, comparator, elem_size); |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
318 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
319 | * // ... some more custom stuff ... |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
320 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
321 | * return (CxList *) list; |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
322 | * } |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
323 | * @endcode |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
324 | * |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
325 | * @param list the list to initialize |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
326 | * @param cl the list class |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
327 | * @param allocator the allocator for the elements |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
328 | * @param comparator a compare function for the elements |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
329 | * @param elem_size the size of one element |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
330 | */ |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
331 | cx_attr_nonnull_arg(1, 2, 3) |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
332 | CX_EXPORT void cx_list_init(struct cx_list_s *list, |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
333 | struct cx_list_class_s *cl, const struct cx_allocator_s *allocator, |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
334 | cx_compare_func comparator, size_t elem_size); |
|
1111
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
335 | |
|
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
336 | /** |
|
677
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
337 | * Returns the number of elements currently stored in the list. |
|
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
338 | * |
|
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
339 | * @param list the list |
|
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
340 | * @return the number of currently stored elements |
|
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
341 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
342 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
343 | CX_EXPORT size_t cxListSize(const CxList *list); |
|
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
344 | |
|
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
345 | /** |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
346 | * Adds an item to the end of the list. |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
347 | * |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
348 | * @param list the list |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
349 | * @param elem a pointer to the element to add |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
350 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
351 | * @retval non-zero memory allocation failure |
|
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
352 | * @see cxListAddArray() |
|
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
353 | * @see cxListEmplace() |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
354 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
355 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
356 | CX_EXPORT int cxListAdd(CxList *list, const void *elem); |
|
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
357 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
358 | /** |
|
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
359 | * Adds multiple items to the end of the list. |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
360 | * |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
361 | * This method is more efficient than invoking cxListAdd() multiple times. |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
362 | * |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
363 | * If there is not enough memory to add all elements, the returned value is |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
364 | * less than @p n. |
|
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
365 | * |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
366 | * If this list is storing pointers instead of objects, @p array is expected to |
|
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
367 | * be an array of pointers. |
|
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
368 | * |
|
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
369 | * @param list the list |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
370 | * @param array a pointer to the elements to add |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
371 | * @param n the number of elements to add |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
372 | * @return the number of added elements |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
373 | * @see cxListEmplaceArray() |
|
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
374 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
375 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
376 | CX_EXPORT size_t cxListAddArray(CxList *list, const void *array, size_t n); |
|
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
377 | |
|
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
378 | /** |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
379 | * Inserts an item at the specified index. |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
380 | * |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
381 | * If the @p index equals the list @c size, this is effectively cxListAdd(). |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
382 | * |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
383 | * @param list the list |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
384 | * @param index the index the element shall have |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
385 | * @param elem a pointer to the element to add |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
386 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
387 | * @retval non-zero memory allocation failure or the index is out of bounds |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
388 | * @see cxListInsertAfter() |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
389 | * @see cxListInsertBefore() |
|
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
390 | * @see cxListEmplaceAt() |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
391 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
392 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
393 | CX_EXPORT int cxListInsert(CxList *list, size_t index, const void *elem); |
|
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
394 | |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
395 | /** |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
396 | * Allocates memory for an element at the specified index and returns a pointer to that memory. |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
397 | * |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
398 | * @remark When the list is storing pointers, this will return a @c void**. |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
399 | * |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
400 | * @param list the list |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
401 | * @param index the index where to emplace the element |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
402 | * @return a pointer to the allocated memory; @c NULL when the operation fails, or the index is out-of-bounds |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
403 | * @see cxListEmplace() |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
404 | * @see cxListEmplaceArrayAt() |
|
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
405 | * @see cxListInsert() |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
406 | */ |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
407 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
408 | CX_EXPORT void *cxListEmplaceAt(CxList *list, size_t index); |
|
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
409 | |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
410 | /** |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
411 | * Allocates memory for an element at the end of the list and returns a pointer to that memory. |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
412 | * |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
413 | * @remark When the list is storing pointers, this will return a @c void**. |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
414 | * |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
415 | * @param list the list |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
416 | * @return a pointer to the allocated memory; @c NULL when the operation fails, or the index is out-of-bounds |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
417 | * @see cxListEmplaceAt() |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
418 | * @see cxListAdd() |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
419 | */ |
|
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
420 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
421 | CX_EXPORT void *cxListEmplace(CxList *list); |
|
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
422 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
423 | /** |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
424 | * Allocates memory for multiple elements and returns an iterator. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
425 | * |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
426 | * The iterator will only iterate over the successfully allocated elements. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
427 | * The @c elem_count attribute is set to that number, and the @c index attribute |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
428 | * will range from zero to @c elem_count minus one. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
429 | * |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
430 | * @remark When the list is storing pointers, the iterator will iterate over |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
431 | * the @c void** elements. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
432 | * |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
433 | * @param list the list |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
434 | * @param index the index where to insert the new data |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
435 | * @param n the number of elements for which to allocate the memory |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
436 | * @return an iterator, iterating over the new memory |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
437 | * @see cxListEmplaceAt() |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
438 | * @see cxListInsertArray() |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
439 | */ |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
440 | cx_attr_nonnull |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
441 | CX_EXPORT CxIterator cxListEmplaceArrayAt(CxList *list, size_t index, size_t n); |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
442 | |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
443 | /** |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
444 | * Allocates memory for multiple elements and returns an iterator. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
445 | * |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
446 | * The iterator will only iterate over the successfully allocated elements. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
447 | * The @c elem_count attribute is set to that number, and the @c index attribute |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
448 | * will range from zero to @c elem_count minus one. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
449 | * |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
450 | * @remark When the list is storing pointers, the iterator will iterate over |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
451 | * the @c void** elements. |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
452 | * |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
453 | * @param list the list |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
454 | * @param n the number of elements for which to allocate the memory |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
455 | * @return an iterator, iterating over the new memory |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
456 | * @see cxListEmplace() |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
457 | * @see cxListAddArray() |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
458 | */ |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
459 | cx_attr_nonnull |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
460 | CX_EXPORT CxIterator cxListEmplaceArray(CxList *list, size_t n); |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
461 | |
|
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
462 | /** |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
463 | * Inserts an item into a sorted list. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
464 | * |
|
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
465 | * If the list is not sorted already, the behavior is undefined. |
|
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
466 | * |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
467 | * @param list the list |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
468 | * @param elem a pointer to the element to add |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
469 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
470 | * @retval non-zero memory allocation failure |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
471 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
472 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
473 | CX_EXPORT int cxListInsertSorted(CxList *list, const void *elem); |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
474 | |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
475 | /** |
|
1428
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
476 | * Inserts an item into a list if it does not exist. |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
477 | * |
|
1428
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
478 | * If the list is not sorted already, this function will check all elements |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
479 | * and append the new element when it was not found. |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
480 | * It is strongly recommended to use this function only on sorted lists, where |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
481 | * the element, if it is not contained, is inserted at the correct position. |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
482 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
483 | * @param list the list |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
484 | * @param elem a pointer to the element to add |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
485 | * @retval zero success (also when the element was already in the list) |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
486 | * @retval non-zero memory allocation failure |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
487 | */ |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
488 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
489 | CX_EXPORT int cxListInsertUnique(CxList *list, const void *elem); |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
490 | |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
491 | /** |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
492 | * Inserts multiple items to the list at the specified index. |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
493 | * If the @p index equals the list size, this is effectively cxListAddArray(). |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
494 | * |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
495 | * This method is usually more efficient than invoking cxListInsert() |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
496 | * multiple times. |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
497 | * |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
498 | * If there is not enough memory to add all elements, the returned value is |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
499 | * less than @p n. |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
500 | * |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
501 | * If this list is storing pointers instead of objects, @p array is expected to |
|
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
502 | * be an array of pointers. |
|
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
503 | * |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
504 | * @param list the list |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
505 | * @param index the index where to add the elements |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
506 | * @param array a pointer to the elements to add |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
507 | * @param n the number of elements to add |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
508 | * @return the number of added elements |
|
1433
81c301a59b7c
add cxListEmplaceArray() and cxListEmplaceArrayAt() as preparation for the clone implementation
Mike Becker <universe@uap-core.de>
parents:
1429
diff
changeset
|
509 | * @see cxListEmplaceArrayAt() |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
510 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
511 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
512 | CX_EXPORT size_t cxListInsertArray(CxList *list, size_t index, const void *array, size_t n); |
|
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
513 | |
|
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
514 | /** |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
515 | * Inserts a sorted array into a sorted list. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
516 | * |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
517 | * This method is usually more efficient than inserting each element separately |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
518 | * because consecutive chunks of sorted data are inserted in one pass. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
519 | * |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
520 | * If there is not enough memory to add all elements, the returned value is |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
521 | * less than @p n. |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
522 | * |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
523 | * If this list is storing pointers instead of objects, @p array is expected to |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
524 | * be an array of pointers. |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
525 | * |
|
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
526 | * If the list is not sorted already, the behavior is undefined. |
|
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
527 | * |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
528 | * @param list the list |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
529 | * @param array a pointer to the elements to add |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
530 | * @param n the number of elements to add |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
531 | * @return the number of added elements |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
532 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
533 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
534 | CX_EXPORT size_t cxListInsertSortedArray(CxList *list, const void *array, size_t n); |
|
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
535 | |
|
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
536 | /** |
|
1428
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
537 | * Inserts an array into a list, skipping duplicates. |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
538 | * |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
539 | * The @p list does not need to be sorted (in contrast to cxListInsertSortedArray()). |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
540 | * But it is strongly recommended to use this function only on sorted lists, |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
541 | * because otherwise it will fall back to an inefficient algorithm which inserts |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
542 | * all elements one by one. |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
543 | * If the @p list is not sorted, the @p array also does not need to be sorted. |
|
0ac4aa1737fd
add support for non-sorted lists in cxListInsertUnique() and cxListInsertUniqueArray()
Mike Becker <universe@uap-core.de>
parents:
1426
diff
changeset
|
544 | * But when the @p list is sorted, the @p array must also be sorted. |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
545 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
546 | * This method is usually more efficient than inserting each element separately |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
547 | * because consecutive chunks of sorted data are inserted in one pass. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
548 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
549 | * If there is not enough memory to add all elements, the returned value is |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
550 | * less than @p n. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
551 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
552 | * @note The return value of this function denotes the number of elements |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
553 | * from the @p sorted_data that are definitely contained in the list after |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
554 | * completing the call. It is @em not the number of elements that were newly |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
555 | * inserted. That means, when no error occurred, the return value should |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
556 | * be @p n. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
557 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
558 | * If this list is storing pointers instead of objects @p array is expected to |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
559 | * be an array of pointers. |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
560 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
561 | * @param list the list |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
562 | * @param array a pointer to the elements to add |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
563 | * @param n the number of elements to add |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
564 | * @return the number of added elements |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
565 | * |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
566 | * @return the number of elements from the @p sorted_data that are definitely present in the list after this call |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
567 | */ |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
568 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
569 | CX_EXPORT size_t cxListInsertUniqueArray(CxList *list, const void *array, size_t n); |
|
1419
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
570 | |
|
e46406fd1b3c
add functions to insert elements into lists/arrays without duplicates - resolves #557
Mike Becker <universe@uap-core.de>
parents:
1418
diff
changeset
|
571 | /** |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
572 | * Inserts an element after the current location of the specified iterator. |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
573 | * |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
574 | * The used iterator remains operational, but all other active iterators should |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
575 | * be considered invalidated. |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
576 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
577 | * If @p iter is not a list iterator, the behavior is undefined. |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
578 | * If @p iter is a past-the-end iterator, the new element gets appended to the list. |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
579 | * |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
580 | * @param iter an iterator |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
581 | * @param elem the element to insert |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
582 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
583 | * @retval non-zero memory allocation failure |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
584 | * @see cxListInsert() |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
585 | * @see cxListInsertBefore() |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
586 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
587 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
588 | CX_EXPORT int cxListInsertAfter(CxIterator *iter, const void *elem); |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
589 | |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
590 | /** |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
591 | * Inserts an element before the current location of the specified iterator. |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
592 | * |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
593 | * The used iterator remains operational, but all other active iterators should |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
594 | * be considered invalidated. |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
595 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
596 | * If @p iter is not a list iterator, the behavior is undefined. |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
597 | * If @p iter is a past-the-end iterator, the new element gets appended to the list. |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
598 | * |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
599 | * @param iter an iterator |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
600 | * @param elem the element to insert |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
601 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
602 | * @retval non-zero memory allocation failure |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
603 | * @see cxListInsert() |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
604 | * @see cxListInsertAfter() |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
605 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
606 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
607 | CX_EXPORT int cxListInsertBefore(CxIterator *iter, const void *elem); |
|
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
608 | |
|
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
609 | /** |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
610 | * Removes the element at the specified index. |
|
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
611 | * |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
612 | * If an element destructor function is specified, it is called before |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
613 | * removing the element. |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
614 | * |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
615 | * @param list the list |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
616 | * @param index the index of the element |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
617 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
618 | * @retval non-zero index out of bounds |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
619 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
620 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
621 | CX_EXPORT int cxListRemove(CxList *list, size_t index); |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
622 | |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
623 | /** |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
624 | * Removes and returns the element at the specified index. |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
625 | * |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
626 | * No destructor is called, and instead the element is copied to the |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
627 | * @p targetbuf which MUST be large enough to hold the removed element. |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
628 | * If the list is storing pointers, only the pointer is copied to @p targetbuf. |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
629 | * |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
630 | * @param list the list |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
631 | * @param index the index of the element |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
632 | * @param targetbuf a buffer where to copy the element |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
633 | * @retval zero success |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
634 | * @retval non-zero index out of bounds |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
635 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
636 | cx_attr_nonnull cx_attr_access_w(3) |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
637 | CX_EXPORT int cxListRemoveAndGet(CxList *list, size_t index, void *targetbuf); |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
638 | |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
639 | /** |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
640 | * Removes and returns the first element of the list. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
641 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
642 | * No destructor is called, and instead the element is copied to the |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
643 | * @p targetbuf which MUST be large enough to hold the removed element. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
644 | * If the list is storing pointers, only the pointer is copied to @p targetbuf. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
645 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
646 | * @param list the list |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
647 | * @param targetbuf a buffer where to copy the element |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
648 | * @retval zero success |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
649 | * @retval non-zero the list is empty |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
650 | * @see cxListPopFront() |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
651 | * @see cxListRemoveAndGetLast() |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
652 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
653 | cx_attr_nonnull cx_attr_access_w(2) |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
654 | CX_EXPORT int cxListRemoveAndGetFirst(CxList *list, void *targetbuf); |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
655 | |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
656 | /** |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
657 | * Removes and returns the first element of the list. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
658 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
659 | * Alias for cxListRemoveAndGetFirst(). |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
660 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
661 | * No destructor is called, and instead the element is copied to the |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
662 | * @p targetbuf which MUST be large enough to hold the removed element. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
663 | * If the list is storing pointers, only the pointer is copied to @p targetbuf. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
664 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
665 | * @param list (@c CxList*) the list |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
666 | * @param targetbuf (@c void*) a buffer where to copy the element |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
667 | * @retval zero success |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
668 | * @retval non-zero the list is empty |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
669 | * @see cxListRemoveAndGetFirst() |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
670 | * @see cxListPop() |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
671 | */ |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
672 | #define cxListPopFront(list, targetbuf) cxListRemoveAndGetFirst((list), (targetbuf)) |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
673 | |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
674 | |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
675 | /** |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
676 | * Removes and returns the last element of the list. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
677 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
678 | * No destructor is called, and instead the element is copied to the |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
679 | * @p targetbuf which MUST be large enough to hold the removed element. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
680 | * If the list is storing pointers, only the pointer is copied to @p targetbuf. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
681 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
682 | * @param list the list |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
683 | * @param targetbuf a buffer where to copy the element |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
684 | * @retval zero success |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
685 | * @retval non-zero the list is empty |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
686 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
687 | cx_attr_nonnull cx_attr_access_w(2) |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
688 | CX_EXPORT int cxListRemoveAndGetLast(CxList *list, void *targetbuf); |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
689 | |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
690 | /** |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
691 | * Removes and returns the last element of the list. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
692 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
693 | * Alias for cxListRemoveAndGetLast(). |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
694 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
695 | * No destructor is called, and instead the element is copied to the |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
696 | * @p targetbuf which MUST be large enough to hold the removed element. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
697 | * If the list is storing pointers, only the pointer is copied to @p targetbuf. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
698 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
699 | * @param list (@c CxList*) the list |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
700 | * @param targetbuf (@c void*) a buffer where to copy the element |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
701 | * @retval zero success |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
702 | * @retval non-zero the list is empty |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
703 | * @see cxListRemoveAndGetLast() |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
704 | * @see cxListPopFront() |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
705 | */ |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
706 | #define cxListPop(list, targetbuf) cxListRemoveAndGetLast((list), (targetbuf)) |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
707 | |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
708 | /** |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
709 | * Removes multiple element starting at the specified index. |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
710 | * |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
711 | * If an element destructor function is specified, it is called for each |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
712 | * element. It is guaranteed that the destructor is called before removing |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
713 | * the element. However, due to possible optimizations, it is neither guaranteed |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
714 | * that the destructors are invoked for all elements before starting to remove |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
715 | * them, nor that the element is removed immediately after the destructor call |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
716 | * before proceeding to the next element. |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
717 | * |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
718 | * @param list the list |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
719 | * @param index the index of the element |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
720 | * @param num the number of elements to remove |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
721 | * @return the actual number of removed elements |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
722 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
723 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
724 | CX_EXPORT size_t cxListRemoveArray(CxList *list, size_t index, size_t num); |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
725 | |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
726 | /** |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
727 | * Removes and returns multiple elements starting at the specified index. |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
728 | * |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
729 | * No destructor is called, and instead the elements are copied to the |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
730 | * @p targetbuf which MUST be large enough to hold all removed elements. |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
731 | * If the list is storing pointers, @p targetbuf is expected to be an array of pointers. |
|
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
732 | * |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
733 | * @param list the list |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
734 | * @param index the index of the element |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
735 | * @param num the number of elements to remove |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
736 | * @param targetbuf a buffer where to copy the elements |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
737 | * @return the actual number of removed elements |
|
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
738 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
739 | cx_attr_nonnull cx_attr_access_w(4) |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
740 | CX_EXPORT size_t cxListRemoveArrayAndGet(CxList *list, size_t index, size_t num, void *targetbuf); |
|
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
741 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
742 | /** |
|
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
743 | * Removes all elements from this list. |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
744 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
745 | * If element destructor functions are specified, they are called for each |
|
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
746 | * element before removing them. |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
747 | * |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
748 | * @param list the list |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
749 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
750 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
751 | CX_EXPORT void cxListClear(CxList *list); |
|
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
752 | |
|
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
753 | /** |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
754 | * Swaps two items in the list. |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
755 | * |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
756 | * Implementations should only allocate temporary memory for the swap if |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
757 | * it is necessary. |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
758 | * |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
759 | * @param list the list |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
760 | * @param i the index of the first element |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
761 | * @param j the index of the second element |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
762 | * @retval zero success |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
763 | * @retval non-zero one of the indices is out of bounds, |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
764 | * or the swap needed extra memory, but allocation failed |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
765 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
766 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
767 | CX_EXPORT int cxListSwap(CxList *list, size_t i, size_t j); |
|
653
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
768 | |
|
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
769 | /** |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
770 | * Returns a pointer to the element at the specified index. |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
771 | * |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
772 | * If the list is storing pointers, returns the pointer stored at the specified index. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
773 | * |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
774 | * @param list the list |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
775 | * @param index the index of the element |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
776 | * @return a pointer to the element or @c NULL if the index is out of bounds |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
777 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
778 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
779 | CX_EXPORT void *cxListAt(const CxList *list, size_t index); |
|
439
9a5adedd6de6
add high-level function cxListAt()
Mike Becker <universe@uap-core.de>
parents:
438
diff
changeset
|
780 | |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
781 | /** |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
782 | * Returns a pointer to the first element. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
783 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
784 | * If the list is storing pointers, returns the first pointer stored in the list. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
785 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
786 | * @param list the list |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
787 | * @return a pointer to the first element or @c NULL if the list is empty |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
788 | */ |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
789 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
790 | CX_EXPORT void *cxListFirst(const CxList *list); |
|
1315
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
791 | |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
792 | /** |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
793 | * Returns a pointer to the last element. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
794 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
795 | * If the list is storing pointers, returns the last pointer stored in the list. |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
796 | * |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
797 | * @param list the list |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
798 | * @return a pointer to the last element or @c NULL if the list is empty |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
799 | */ |
|
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
800 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
801 | CX_EXPORT void *cxListLast(const CxList *list); |
|
1287
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
802 | |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
803 | /** |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
804 | * Sets the element at the specified index in the list. |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
805 | * |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
806 | * This overwrites the element in-place without calling any destructor |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
807 | * on the overwritten element. |
|
1287
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
808 | * |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
809 | * @param list the list to set the element in |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
810 | * @param index the index to set the element at |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
811 | * @param elem element to set |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
812 | * @retval zero on success |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
813 | * @retval non-zero when index is out of bounds |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
814 | */ |
|
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
815 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
816 | CX_EXPORT int cxListSet(CxList *list, size_t index, const void *elem); |
|
1287
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
817 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
818 | /** |
|
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
819 | * Returns an iterator pointing to the item at the specified index. |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
820 | * |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
821 | * The returned iterator is position-aware. |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
822 | * |
|
1343
b2ba79f4cb62
also support NULL in index-based iterator generating functions
Mike Becker <universe@uap-core.de>
parents:
1341
diff
changeset
|
823 | * If the index is out of range or @p list is @c NULL, a past-the-end iterator will be returned. |
|
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
824 | * |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
825 | * @param list the list |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
826 | * @param index the index where the iterator shall point at |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
827 | * @return a new iterator |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
828 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
829 | cx_attr_nodiscard |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
830 | CX_EXPORT CxIterator cxListIteratorAt(const CxList *list, size_t index); |
|
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
831 | |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
832 | /** |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
833 | * Returns a backwards iterator pointing to the item at the specified index. |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
834 | * |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
835 | * The returned iterator is position-aware. |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
836 | * |
|
1343
b2ba79f4cb62
also support NULL in index-based iterator generating functions
Mike Becker <universe@uap-core.de>
parents:
1341
diff
changeset
|
837 | * If the index is out of range or @p list is @c NULL, a past-the-end iterator will be returned. |
|
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
838 | * |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
839 | * @param list the list |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
840 | * @param index the index where the iterator shall point at |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
841 | * @return a new iterator |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
842 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
843 | cx_attr_nodiscard |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
844 | CX_EXPORT CxIterator cxListBackwardsIteratorAt(const CxList *list, size_t index); |
|
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
845 | |
|
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
846 | /** |
|
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
847 | * Returns an iterator pointing to the first item of the list. |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
848 | * |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
849 | * The returned iterator is position-aware. |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
850 | * |
|
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
851 | * If the list is empty or @c NULL, a past-the-end iterator will be returned. |
|
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
852 | * |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
853 | * @param list the list |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
854 | * @return a new iterator |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
855 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
856 | cx_attr_nodiscard |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
857 | CX_EXPORT CxIterator cxListIterator(const CxList *list); |
|
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
858 | |
|
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
859 | /** |
|
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
860 | * Returns a backwards iterator pointing to the last item of the list. |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
861 | * |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
862 | * The returned iterator is position-aware. |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
863 | * |
|
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
864 | * If the list is empty or @c NULL, a past-the-end iterator will be returned. |
|
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
865 | * |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
866 | * @param list the list |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
867 | * @return a new iterator |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
868 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
869 | cx_attr_nodiscard |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
870 | CX_EXPORT CxIterator cxListBackwardsIterator(const CxList *list); |
|
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
871 | |
|
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
653
diff
changeset
|
872 | /** |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
873 | * Returns the index of the first element that equals @p elem. |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
874 | * |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
875 | * Determining equality is performed by the list's comparator function. |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
876 | * |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
877 | * @param list the list |
|
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
878 | * @param elem the element to find |
|
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
879 | * @return the index of the element or the size of the list when the element is not found |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
880 | * @see cxListIndexValid() |
|
1293
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
881 | * @see cxListContains() |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
882 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
883 | cx_attr_nonnull cx_attr_nodiscard |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
884 | CX_EXPORT size_t cxListFind(const CxList *list, const void *elem); |
|
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
885 | |
|
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
886 | /** |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
887 | * Checks if the list contains the specified element. |
|
1293
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
888 | * |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
889 | * The elements are compared with the list's comparator function. |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
890 | * |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
891 | * @param list the list |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
892 | * @param elem the element to find |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
893 | * @retval true if the element is contained |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
894 | * @retval false if the element is not contained |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
895 | * @see cxListFind() |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
896 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
897 | cx_attr_nonnull cx_attr_nodiscard |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
898 | CX_EXPORT bool cxListContains(const CxList* list, const void* elem); |
|
1293
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
899 | |
|
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
900 | /** |
|
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
901 | * Checks if the specified index is within bounds. |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
902 | * |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
903 | * @param list the list |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
904 | * @param index the index |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
905 | * @retval true if the index is within bounds |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
906 | * @retval false if the index is out of bounds |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
907 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
908 | cx_attr_nonnull cx_attr_nodiscard |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
909 | CX_EXPORT bool cxListIndexValid(const CxList *list, size_t index); |
|
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
910 | |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
911 | /** |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
912 | * Removes and returns the index of the first element that equals @p elem. |
|
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
913 | * |
|
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
914 | * Determining equality is performed by the list's comparator function. |
|
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
915 | * |
|
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
916 | * @param list the list |
|
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
917 | * @param elem the element to find and remove |
|
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
918 | * @return the index of the now removed element or the list size |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
919 | * when the element is not found or could not be removed |
|
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
920 | * @see cxListIndexValid() |
|
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
921 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
922 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
923 | CX_EXPORT size_t cxListFindRemove(CxList *list, const void *elem); |
|
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
924 | |
|
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
925 | /** |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
926 | * Sorts the list. |
|
470
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
927 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
928 | * @remark The underlying sort algorithm is implementation defined. |
|
470
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
929 | * |
|
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
930 | * @param list the list |
|
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
931 | */ |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
932 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
933 | CX_EXPORT void cxListSort(CxList *list); |
| 404 | 934 | |
|
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
935 | /** |
| 490 | 936 | * Reverses the order of the items. |
| 937 | * | |
| 938 | * @param list the list | |
| 939 | */ | |
|
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
940 | cx_attr_nonnull |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
941 | CX_EXPORT void cxListReverse(CxList *list); |
| 490 | 942 | |
| 943 | /** | |
|
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
944 | * Compares a list to another list of the same type. |
|
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
945 | * |
|
618
1f5a8f6f3015
#219 array list: implement compare
Mike Becker <universe@uap-core.de>
parents:
528
diff
changeset
|
946 | * First, the list sizes are compared. |
|
1f5a8f6f3015
#219 array list: implement compare
Mike Becker <universe@uap-core.de>
parents:
528
diff
changeset
|
947 | * If they match, the lists are compared element-wise. |
|
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
948 | * |
|
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
949 | * @param list the list |
|
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
950 | * @param other the list to compare to |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
951 | * @retval zero both lists are equal element wise |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
952 | * @retval negative the first list is smaller, |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
953 | * or the first non-equal element in the first list is smaller |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
954 | * @retval positive the first list is larger |
|
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
955 | * or the first non-equal element in the first list is larger |
|
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
956 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
957 | cx_attr_nonnull cx_attr_nodiscard |
|
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
958 | CX_EXPORT int cxListCompare(const CxList *list, const CxList *other); |
|
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
959 | |
|
503
a89857072ace
add new destructor API and apply it to CxList
Mike Becker <universe@uap-core.de>
parents:
500
diff
changeset
|
960 | /** |
|
528
4fbfac557df8
#179 improve API for list content destruction
Mike Becker <universe@uap-core.de>
parents:
526
diff
changeset
|
961 | * Deallocates the memory of the specified list structure. |
|
4fbfac557df8
#179 improve API for list content destruction
Mike Becker <universe@uap-core.de>
parents:
526
diff
changeset
|
962 | * |
|
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
963 | * Also calls the content destructor functions for each element, if specified. |
|
503
a89857072ace
add new destructor API and apply it to CxList
Mike Becker <universe@uap-core.de>
parents:
500
diff
changeset
|
964 | * |
|
1424
563033aa998c
fixes tons of typos and grammar issues across the documentation - fixes #667
Mike Becker <universe@uap-core.de>
parents:
1423
diff
changeset
|
965 | * @param list the list that shall be freed |
|
503
a89857072ace
add new destructor API and apply it to CxList
Mike Becker <universe@uap-core.de>
parents:
500
diff
changeset
|
966 | */ |
|
1426
3a89b31f0724
clean up header files and adds support for comparing arbitrary strings with string.h functions
Mike Becker <universe@uap-core.de>
parents:
1424
diff
changeset
|
967 | CX_EXPORT void cxListFree(CxList *list); |
|
503
a89857072ace
add new destructor API and apply it to CxList
Mike Becker <universe@uap-core.de>
parents:
500
diff
changeset
|
968 | |
|
704
35f06c5eeb0e
add empty list implementation - fixes #258
Mike Becker <universe@uap-core.de>
parents:
699
diff
changeset
|
969 | |
|
1436
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
970 | /** |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
971 | * Performs a deep clone of one list into another. |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
972 | * |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
973 | * If the destination list already contains elements, the cloned elements |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
974 | * are appended to that list. |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
975 | * |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
976 | * @attention If the cloned elements need to be destroyed by a destructor |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
977 | * function, you must make sure that the destination list also uses this |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
978 | * destructor function. |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
979 | * |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
980 | * @param dst the destination list |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
981 | * @param src the source list |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
982 | * @param clone_func the clone function for the elements |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
983 | * @param clone_allocator the allocator that is passed to the clone function |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
984 | * @param data optional additional data that is passed to the clone function |
|
1444
dd9dcbb39c2f
make clone functions return int instead of size_t
Mike Becker <universe@uap-core.de>
parents:
1436
diff
changeset
|
985 | * @retval zero when all elements were successfully cloned |
|
dd9dcbb39c2f
make clone functions return int instead of size_t
Mike Becker <universe@uap-core.de>
parents:
1436
diff
changeset
|
986 | * @retval non-zero when an allocation error occurred |
|
1479
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
987 | * @see cxListCloneSimple() |
|
1436
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
988 | */ |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
989 | cx_attr_nonnull_arg(1, 2, 3) |
|
1444
dd9dcbb39c2f
make clone functions return int instead of size_t
Mike Becker <universe@uap-core.de>
parents:
1436
diff
changeset
|
990 | CX_EXPORT int cxListClone(CxList *dst, const CxList *src, |
|
1436
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
991 | cx_clone_func clone_func, const CxAllocator *clone_allocator, void *data); |
|
c331add0d9f8
add cxListClone() - resolves #744 except for test coverage
Mike Becker <universe@uap-core.de>
parents:
1433
diff
changeset
|
992 | |
|
1453
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
993 | /** |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
994 | * Clones elements from a list only if they are not present in another list. |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
995 | * |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
996 | * If the @p minuend does not contain duplicates, this is equivalent to adding |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
997 | * the set difference to the destination list. |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
998 | * |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
999 | * This function is optimized for the case when both the @p minuend and the |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1000 | * @p subtrahend are sorted. |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1001 | * |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1002 | * @param dst the destination list |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1003 | * @param minuend the list to subtract elements from |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1004 | * @param subtrahend the elements that shall be subtracted |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1005 | * @param clone_func the clone function for the elements |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1006 | * @param clone_allocator the allocator that is passed to the clone function |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1007 | * @param data optional additional data that is passed to the clone function |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1008 | * @retval zero when the elements were successfully cloned |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1009 | * @retval non-zero when an allocation error occurred |
|
1479
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1010 | * @see cxListDifferenceSimple() |
|
1453
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1011 | */ |
|
1468
0f4d90a1ae23
fix clone_func not checked for being nonnull
Mike Becker <universe@uap-core.de>
parents:
1466
diff
changeset
|
1012 | cx_attr_nonnull_arg(1, 2, 3, 4) |
|
1453
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1013 | CX_EXPORT int cxListDifference(CxList *dst, |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1014 | const CxList *minuend, const CxList *subtrahend, |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1015 | cx_clone_func clone_func, const CxAllocator *clone_allocator, void *data); |
|
b6fc5b1d5c5d
add implementation for cxListDifference() - issue #745
Mike Becker <universe@uap-core.de>
parents:
1444
diff
changeset
|
1016 | |
|
1465
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1017 | /** |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1018 | * Clones elements from a list only if they are also present in another list. |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1019 | * |
|
1477
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1020 | * This function is optimized for the case when both the @p src and the |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1021 | * @p other list are sorted. |
|
1465
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1022 | * |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1023 | * If the destination list already contains elements, the intersection is appended |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1024 | * to that list. |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1025 | * |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1026 | * @param dst the destination list |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1027 | * @param src the list to clone the elements from |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1028 | * @param other the list to check the elements for existence |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1029 | * @param clone_func the clone function for the elements |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1030 | * @param clone_allocator the allocator that is passed to the clone function |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1031 | * @param data optional additional data that is passed to the clone function |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1032 | * @retval zero when the elements were successfully cloned |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1033 | * @retval non-zero when an allocation error occurred |
|
1479
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1034 | * @see cxListIntersectionSimple() |
|
1465
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1035 | */ |
|
1468
0f4d90a1ae23
fix clone_func not checked for being nonnull
Mike Becker <universe@uap-core.de>
parents:
1466
diff
changeset
|
1036 | cx_attr_nonnull_arg(1, 2, 3, 4) |
|
1465
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1037 | CX_EXPORT int cxListIntersection(CxList *dst, const CxList *src, const CxList *other, |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1038 | cx_clone_func clone_func, const CxAllocator *clone_allocator, void *data); |
|
dc886f1a6155
specify the intersection functions
Mike Becker <universe@uap-core.de>
parents:
1453
diff
changeset
|
1039 | |
|
1477
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1040 | /** |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1041 | * Performs a deep clone of one list into another, skipping duplicates. |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1042 | * |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1043 | * This function is optimized for the case when both the @p src and the |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1044 | * @p other list are sorted. |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1045 | * In that case, the union will also be sorted. |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1046 | * |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1047 | * If the destination list already contains elements, the union is appended |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1048 | * to that list. In that case the destination is not necessarily sorted. |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1049 | * |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1050 | * @param dst the destination list |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1051 | * @param src the primary source list |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1052 | * @param other the other list, where elements are only cloned from |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1053 | * when they are not in @p src |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1054 | * @param clone_func the clone function for the elements |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1055 | * @param clone_allocator the allocator that is passed to the clone function |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1056 | * @param data optional additional data that is passed to the clone function |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1057 | * @retval zero when the elements were successfully cloned |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1058 | * @retval non-zero when an allocation error occurred |
|
1479
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1059 | * @see cxListUnionSimple() |
|
1477
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1060 | */ |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1061 | cx_attr_nonnull_arg(1, 2, 3, 4) |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1062 | CX_EXPORT int cxListUnion(CxList *dst, const CxList *src, const CxList *other, |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1063 | cx_clone_func clone_func, const CxAllocator *clone_allocator, void *data); |
|
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1064 | |
|
1479
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1065 | /** |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1066 | * Performs a shallow clone of one list into another. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1067 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1068 | * This function uses the default allocator, if needed, and performs |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1069 | * shallow clones with @c memcpy(). |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1070 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1071 | * If the destination list already contains elements, the cloned elements |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1072 | * are appended to that list. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1073 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1074 | * @attention If the cloned elements need to be destroyed by a destructor |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1075 | * function, you must make sure that the destination list also uses this |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1076 | * destructor function. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1077 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1078 | * @param dst the destination list |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1079 | * @param src the source list |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1080 | * @retval zero when all elements were successfully cloned |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1081 | * @retval non-zero when an allocation error occurred |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1082 | * @see cxListClone() |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1083 | */ |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1084 | cx_attr_nonnull |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1085 | CX_EXPORT int cxListCloneSimple(CxList *dst, const CxList *src); |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1086 | |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1087 | /** |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1088 | * Clones elements from a list only if they are not present in another list. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1089 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1090 | * This function uses the default allocator, if needed, and performs |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1091 | * shallow clones with @c memcpy(). |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1092 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1093 | * If the @p minuend does not contain duplicates, this is equivalent to adding |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1094 | * the set difference to the destination list. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1095 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1096 | * This function is optimized for the case when both the @p minuend and the |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1097 | * @p subtrahend are sorted. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1098 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1099 | * @param dst the destination list |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1100 | * @param minuend the list to subtract elements from |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1101 | * @param subtrahend the elements that shall be subtracted |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1102 | * @retval zero when the elements were successfully cloned |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1103 | * @retval non-zero when an allocation error occurred |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1104 | * @see cxListDifference() |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1105 | */ |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1106 | cx_attr_nonnull |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1107 | CX_EXPORT int cxListDifferenceSimple(CxList *dst, |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1108 | const CxList *minuend, const CxList *subtrahend); |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1109 | |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1110 | /** |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1111 | * Clones elements from a list only if they are also present in another list. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1112 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1113 | * This function uses the default allocator, if needed, and performs |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1114 | * shallow clones with @c memcpy(). |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1115 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1116 | * This function is optimized for the case when both the @p src and the |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1117 | * @p other list are sorted. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1118 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1119 | * If the destination list already contains elements, the intersection is appended |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1120 | * to that list. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1121 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1122 | * @param dst the destination list |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1123 | * @param src the list to clone the elements from |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1124 | * @param other the list to check the elements for existence |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1125 | * @retval zero when the elements were successfully cloned |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1126 | * @retval non-zero when an allocation error occurred |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1127 | * @see cxListIntersection() |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1128 | */ |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1129 | cx_attr_nonnull |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1130 | CX_EXPORT int cxListIntersectionSimple(CxList *dst, const CxList *src, const CxList *other); |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1131 | |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1132 | /** |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1133 | * Performs a deep clone of one list into another, skipping duplicates. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1134 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1135 | * This function uses the default allocator, if needed, and performs |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1136 | * shallow clones with @c memcpy(). |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1137 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1138 | * This function is optimized for the case when both the @p src and the |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1139 | * @p other list are sorted. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1140 | * In that case, the union will also be sorted. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1141 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1142 | * If the destination list already contains elements, the union is appended |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1143 | * to that list. In that case the destination is not necessarily sorted. |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1144 | * |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1145 | * @param dst the destination list |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1146 | * @param src the primary source list |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1147 | * @param other the other list, where elements are only cloned from |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1148 | * when they are not in @p src |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1149 | * @retval zero when the elements were successfully cloned |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1150 | * @retval non-zero when an allocation error occurred |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1151 | * @see cxListUnion() |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1152 | */ |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1153 | cx_attr_nonnull |
|
ac1baaed2fd7
implement simple versions of the clone functions
Mike Becker <universe@uap-core.de>
parents:
1477
diff
changeset
|
1154 | CX_EXPORT int cxListUnionSimple(CxList *dst, const CxList *src, const CxList *other); |
|
1477
9170a7dff573
implement cxListUnion() - resolves #755
Mike Becker <universe@uap-core.de>
parents:
1468
diff
changeset
|
1155 | |
|
1482
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1156 | /** |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1157 | * Asks the list to reserve enough memory for a given total number of elements. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1158 | * |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1159 | * List implementations are free to choose if reserving memory upfront makes |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1160 | * sense. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1161 | * For example, array-based implementations usually do support reserving memory |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1162 | * for additional elements while linked lists usually don't. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1163 | * |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1164 | * @note When the requested capacity is smaller than the current size, |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1165 | * this function returns zero without performing any action. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1166 | * |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1167 | * @param list the list |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1168 | * @param capacity the expected total number of elements |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1169 | * @retval zero on success or when overallocation is not supported |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1170 | * @retval non-zero when an allocation error occurred |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1171 | * @see cxListShrink() |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1172 | */ |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1173 | cx_attr_nonnull |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1174 | CX_EXPORT int cxListReserve(CxList *list, size_t capacity); |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1175 | |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1176 | /** |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1177 | * Advises the list to free any overallocated memory. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1178 | * |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1179 | * Lists that do not support overallocation simply return zero. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1180 | * |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1181 | * This function usually returns zero, except for very special and custom |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1182 | * list and/or allocator implementations where freeing memory can fail. |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1183 | * |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1184 | * @param list the list |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1185 | * @return usually zero |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1186 | */ |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1187 | cx_attr_nonnull |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1188 | CX_EXPORT int cxListShrink(CxList *list); |
|
6769cb72521b
implement a new allocation strategy for array lists and add cxListReserve() and cxListShrink()
Mike Becker <universe@uap-core.de>
parents:
1479
diff
changeset
|
1189 | |
| 416 | 1190 | #ifdef __cplusplus |
|
628
1e2be40f0cb5
use //-style single line comments everywhere
Mike Becker <universe@uap-core.de>
parents:
621
diff
changeset
|
1191 | } // extern "C" |
| 416 | 1192 | #endif |
| 1193 | ||
|
628
1e2be40f0cb5
use //-style single line comments everywhere
Mike Becker <universe@uap-core.de>
parents:
621
diff
changeset
|
1194 | #endif // UCX_LIST_H |