Fri, 23 May 2025 12:44:24 +0200
make test-compile depend on both static and shared
the shared lib is not needed for the tests,
but when run with coverage, gcov will be confused
when outdated line information is available from
a previous shared build
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 | |
415 | 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:
415
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:
415
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:
415
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 | /** | |
739
529c35a768f3
fix typo in list.h
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
708
diff
changeset
|
82 | * Member function for inserting a single element. |
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
83 | * The data pointer may be @c NULL in which case the function shall only allocate memory. |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
84 | * Returns a pointer to the data of the inserted element. |
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
85 | */ |
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
86 | void *(*insert_element)( |
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
87 | struct cx_list_s *list, |
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
88 | size_t index, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
89 | const void *data |
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
90 | ); |
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
91 | |
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
92 | /** |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
93 | * 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
|
94 | * |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
95 | * @see cx_list_default_insert_array() |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
96 | */ |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
97 | size_t (*insert_array)( |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
98 | struct cx_list_s *list, |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
99 | size_t index, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
100 | const void *data, |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
101 | size_t n |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
102 | ); |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
103 | |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
104 | /** |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
105 | * Member function for inserting sorted elements into a sorted list. |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
106 | * |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
107 | * @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
|
108 | */ |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
109 | size_t (*insert_sorted)( |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
110 | struct cx_list_s *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
111 | const void *sorted_data, |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
112 | size_t n |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
113 | ); |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
114 | |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
115 | /** |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
116 | * 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
|
117 | */ |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
118 | int (*insert_iter)( |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
119 | struct cx_iterator_s *iter, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
120 | const void *elem, |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
121 | int prepend |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
122 | ); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
123 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
124 | /** |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
125 | * 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
|
126 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
127 | * 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
|
128 | * 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
|
129 | * 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
|
130 | * |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
131 | * 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
|
132 | * 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
|
133 | */ |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
134 | size_t (*remove)( |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
135 | struct cx_list_s *list, |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
136 | size_t index, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
137 | size_t num, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
138 | void *targetbuf |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
139 | ); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
140 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
141 | /** |
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
142 | * 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
|
143 | */ |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
144 | 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
|
145 | |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
146 | /** |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
147 | * 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
|
148 | * |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
149 | * @see cx_list_default_swap() |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
150 | */ |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
151 | int (*swap)( |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
152 | struct cx_list_s *list, |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
153 | size_t i, |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
154 | size_t j |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
155 | ); |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
156 | |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
157 | /** |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
158 | * Member function for element lookup. |
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 | void *(*at)( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
161 | const struct cx_list_s *list, |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
162 | size_t index |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
163 | ); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
164 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
165 | /** |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
166 | * 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
|
167 | */ |
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
168 | size_t (*find_remove)( |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
169 | struct cx_list_s *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
170 | const void *elem, |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
171 | bool remove |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
172 | ); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
173 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
174 | /** |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
175 | * Member function for sorting the list. |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
176 | * |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
177 | * @see cx_list_default_sort() |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
178 | */ |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
179 | void (*sort)(struct cx_list_s *list); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
180 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
181 | /** |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
182 | * 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
|
183 | * to another list of the same type. |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
184 | * If set to @c NULL, comparison won't be optimized. |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
185 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
186 | cx_attr_nonnull |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
187 | int (*compare)( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
188 | const struct cx_list_s *list, |
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
189 | const struct cx_list_s *other |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
190 | ); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
191 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
192 | /** |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
193 | * 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
|
194 | */ |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
195 | void (*reverse)(struct cx_list_s *list); |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
196 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
197 | /** |
640
55cc3b373c5e
simplify list class - fixes #236
Mike Becker <universe@uap-core.de>
parents:
638
diff
changeset
|
198 | * 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
|
199 | */ |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
200 | struct cx_iterator_s (*iterator)( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
201 | const struct cx_list_s *list, |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
202 | size_t index, |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
203 | bool backward |
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
204 | ); |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
205 | }; |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
206 | |
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
207 | /** |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
208 | * 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
|
209 | */ |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
210 | 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
|
211 | |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
212 | /** |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
213 | * 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
|
214 | * |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
215 | * 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
|
216 | * |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
217 | * You can use this is a placeholder for initializing CxList pointers |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
218 | * 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
|
219 | */ |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
220 | cx_attr_export |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
221 | extern CxList *const cxEmptyList; |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
222 | |
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
223 | /** |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
224 | * 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
|
225 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
226 | * 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
|
227 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
228 | * 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
|
229 | * version for your list. |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
230 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
231 | * @param list the list |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
232 | * @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
|
233 | * @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
|
234 | * @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
|
235 | * @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
|
236 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
237 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
238 | cx_attr_export |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
239 | size_t cx_list_default_insert_array( |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
240 | struct cx_list_s *list, |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
241 | size_t index, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
242 | const void *data, |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
243 | size_t n |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
244 | ); |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
245 | |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
246 | /** |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
247 | * 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
|
248 | * |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
249 | * 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
|
250 | * of sorted data. |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
251 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
252 | * 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
|
253 | * |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
254 | * 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
|
255 | * version for your list. |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
256 | * |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
257 | * @param list the list |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
258 | * @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
|
259 | * @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
|
260 | * @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
|
261 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
262 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
263 | cx_attr_export |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
264 | size_t 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
|
265 | struct cx_list_s *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
266 | const void *sorted_data, |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
267 | size_t n |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
268 | ); |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
269 | |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
270 | /** |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
271 | * Default unoptimized sort implementation. |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
272 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
273 | * 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
|
274 | * 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
|
275 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
276 | * 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
|
277 | * version for your list. |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
278 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
279 | * @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
|
280 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
281 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
282 | cx_attr_export |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
283 | void cx_list_default_sort(struct cx_list_s *list); |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
284 | |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
285 | /** |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
286 | * Default unoptimized swap implementation. |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
287 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
288 | * 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
|
289 | * version for your list. |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
290 | * |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
291 | * @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
|
292 | * @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
|
293 | * @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
|
294 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
295 | * @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
|
296 | * 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
|
297 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
298 | cx_attr_nonnull |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
299 | cx_attr_export |
875
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
300 | int cx_list_default_swap(struct cx_list_s *list, size_t i, size_t j); |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
301 | |
ee84ac776cbc
add default impl for some list member functions
Mike Becker <universe@uap-core.de>
parents:
856
diff
changeset
|
302 | /** |
1111
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
303 | * 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
|
304 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
305 | * 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
|
306 | * The purpose of this function is to be called in the initialization code |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
307 | * of your list, to set certain members correctly. |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
308 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
309 | * 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
|
310 | * #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
|
311 | * class accordingly and make sure that you can implement your list as if |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
312 | * it was only storing objects and the wrapper will automatically enable |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
313 | * 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
|
314 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
315 | * @par Example |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
316 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
317 | * @code |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
318 | * CxList *myCustomListCreate( |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
319 | * 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
|
320 | * 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
|
321 | * 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
|
322 | * ) { |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
323 | * 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
|
324 | * allocator = cxDefaultAllocator; |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
325 | * } |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
326 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
327 | * 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
|
328 | * 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
|
329 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
330 | * // initialize |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
331 | * 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
|
332 | * 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
|
333 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
334 | * // ... 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
|
335 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
336 | * 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
|
337 | * } |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
338 | * @endcode |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
339 | * |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
340 | * @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
|
341 | * @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
|
342 | * @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
|
343 | * @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
|
344 | * @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
|
345 | */ |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
346 | cx_attr_nonnull_arg(1, 2, 3) |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
347 | cx_attr_export |
1111
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
348 | void cx_list_init( |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
349 | struct cx_list_s *list, |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
350 | struct cx_list_class_s *cl, |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
351 | const struct cx_allocator_s *allocator, |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
352 | 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
|
353 | 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
|
354 | ); |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
355 | |
78eeeb950883
remove API for changing the store_pointer property after list creation
Mike Becker <universe@uap-core.de>
parents:
1109
diff
changeset
|
356 | /** |
677
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
357 | * 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
|
358 | * |
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
359 | * @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
|
360 | * @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
|
361 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
362 | cx_attr_nonnull |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
363 | static inline size_t cxListSize(const CxList *list) { |
856
6bbbf219251d
fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents:
854
diff
changeset
|
364 | return list->collection.size; |
677
b09aae58bba4
refactoring of collections to make use of destructors in map implementations
Mike Becker <universe@uap-core.de>
parents:
669
diff
changeset
|
365 | } |
641
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
366 | |
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
367 | /** |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
368 | * 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
|
369 | * |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
370 | * @param list the list |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
371 | * @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
|
372 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
373 | * @retval non-zero memory allocation failure |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
374 | * @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
|
375 | * @see cxListEmplace() |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
376 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
377 | cx_attr_nonnull |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
378 | static inline int cxListAdd( |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
379 | CxList *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
380 | const void *elem |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
381 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
382 | list->collection.sorted = false; |
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
383 | return list->cl->insert_element(list, list->collection.size, elem) == NULL; |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
384 | } |
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
385 | |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
386 | /** |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
387 | * Adds multiple items to the end of the list. |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
388 | * |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
389 | * This method is more efficient than invoking cxListAdd() multiple times. |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
390 | * |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
391 | * 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
|
392 | * less than @p n. |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
393 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
394 | * 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
|
395 | * be an array of pointers. |
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
396 | * |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
397 | * @param list the list |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
398 | * @param array a pointer to the elements to add |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
399 | * @param n the number of elements to add |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
400 | * @return the number of added elements |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
401 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
402 | cx_attr_nonnull |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
403 | static inline size_t cxListAddArray( |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
404 | CxList *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
405 | const void *array, |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
406 | size_t n |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
407 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
408 | list->collection.sorted = false; |
856
6bbbf219251d
fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents:
854
diff
changeset
|
409 | return list->cl->insert_array(list, list->collection.size, array, n); |
629
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
410 | } |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
411 | |
6c81ee4f11ad
#224 add cxListAddArray()
Mike Becker <universe@uap-core.de>
parents:
628
diff
changeset
|
412 | /** |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
413 | * Inserts an item at the specified index. |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
414 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
415 | * If @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
|
416 | * |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
417 | * @param list the list |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
418 | * @param index the index the element shall have |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
419 | * @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
|
420 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
421 | * @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
|
422 | * @see cxListInsertAfter() |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
423 | * @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
|
424 | * @see cxListEmplaceAt() |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
425 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
426 | cx_attr_nonnull |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
427 | static inline int cxListInsert( |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
428 | CxList *list, |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
429 | size_t index, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
430 | const void *elem |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
431 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
432 | list->collection.sorted = false; |
1316
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
433 | return list->cl->insert_element(list, index, elem) == NULL; |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
434 | } |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
435 | |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
436 | /** |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
437 | * 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
|
438 | * |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
439 | * @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
|
440 | * |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
441 | * @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
|
442 | * @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
|
443 | * @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
|
444 | * @see cxListEmplace() |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
445 | * @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
|
446 | */ |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
447 | cx_attr_nonnull |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
448 | static inline void *cxListEmplaceAt(CxList *list, size_t index) { |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
449 | list->collection.sorted = false; |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
450 | return list->cl->insert_element(list, index, NULL); |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
451 | } |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
452 | |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
453 | |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
454 | /** |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
455 | * 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
|
456 | * |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
457 | * @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
|
458 | * |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
459 | * @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
|
460 | * @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
|
461 | * @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
|
462 | * @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
|
463 | */ |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
464 | cx_attr_nonnull |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
465 | static inline void *cxListEmplace(CxList *list) { |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
466 | list->collection.sorted = false; |
c41538edfcef
add cxListEmplace() and cxListEmplaceAt() plus some improvements to the array list implementation
Mike Becker <universe@uap-core.de>
parents:
1315
diff
changeset
|
467 | return list->cl->insert_element(list, list->collection.size, NULL); |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
468 | } |
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
469 | |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
470 | /** |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
471 | * 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
|
472 | * |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
473 | * 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
|
474 | * |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
475 | * @param list the list |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
476 | * @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
|
477 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
478 | * @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
|
479 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
480 | cx_attr_nonnull |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
481 | static inline int cxListInsertSorted( |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
482 | CxList *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
483 | const void *elem |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
484 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
485 | list->collection.sorted = true; // guaranteed by definition |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
486 | const void *data = list->collection.store_pointer ? &elem : elem; |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
487 | return list->cl->insert_sorted(list, data, 1) == 0; |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
488 | } |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
489 | |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
490 | /** |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
491 | * Inserts multiple items to the list at the specified index. |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
492 | * If @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
|
493 | * |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
494 | * This method is usually more efficient than invoking cxListInsert() |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
495 | * multiple times. |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
496 | * |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
497 | * 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
|
498 | * less than @p n. |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
499 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
500 | * 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
|
501 | * be an array of pointers. |
d402fead3386
add new pointer list wrapper - resolves #234
Mike Becker <universe@uap-core.de>
parents:
640
diff
changeset
|
502 | * |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
503 | * @param list the list |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
504 | * @param index the index where to add the elements |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
505 | * @param array a pointer to the elements to add |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
506 | * @param n the number of elements to add |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
507 | * @return the number of added elements |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
508 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
509 | cx_attr_nonnull |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
510 | static inline size_t cxListInsertArray( |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
511 | CxList *list, |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
512 | size_t index, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
513 | const void *array, |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
514 | size_t n |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
515 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
516 | list->collection.sorted = false; |
638
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
517 | return list->cl->insert_array(list, index, array, n); |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
518 | } |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
519 | |
eafb45eefc51
add cxListInsertArray() - fixes #224
Mike Becker <universe@uap-core.de>
parents:
630
diff
changeset
|
520 | /** |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
521 | * 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
|
522 | * |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
523 | * This method is usually more efficient than inserting each element separately, |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
524 | * 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
|
525 | * |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
526 | * 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
|
527 | * 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
|
528 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
529 | * 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
|
530 | * 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
|
531 | * |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
532 | * 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
|
533 | * |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
534 | * @param list the list |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
535 | * @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
|
536 | * @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
|
537 | * @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
|
538 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
539 | cx_attr_nonnull |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
540 | static inline size_t cxListInsertSortedArray( |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
541 | CxList *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
542 | const void *array, |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
543 | size_t n |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
544 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
545 | list->collection.sorted = true; // guaranteed by definition |
876
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
546 | return list->cl->insert_sorted(list, array, n); |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
547 | } |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
548 | |
f4ce7df9cff0
add stupid default implementation for high level insertion sort
Mike Becker <universe@uap-core.de>
parents:
875
diff
changeset
|
549 | /** |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
550 | * 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
|
551 | * |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
552 | * 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
|
553 | * be considered invalidated. |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
554 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
555 | * 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
|
556 | * 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
|
557 | * |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
558 | * @param iter an iterator |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
559 | * @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
|
560 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
561 | * @retval non-zero memory allocation failure |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
562 | * @see cxListInsert() |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
563 | * @see cxListInsertBefore() |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
564 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
565 | cx_attr_nonnull |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
566 | static inline int cxListInsertAfter( |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
567 | CxIterator *iter, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
568 | const void *elem |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
569 | ) { |
1201
84fc692d2708
fix list.h was not includable by C++
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1193
diff
changeset
|
570 | CxList* list = (CxList*)iter->src_handle.m; |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
571 | list->collection.sorted = false; |
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
572 | return list->cl->insert_iter(iter, elem, 0); |
499
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 | |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
575 | /** |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
576 | * 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
|
577 | * |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
578 | * 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
|
579 | * be considered invalidated. |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
580 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
581 | * 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
|
582 | * 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
|
583 | * |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
584 | * @param iter an iterator |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
585 | * @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
|
586 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
587 | * @retval non-zero memory allocation failure |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
588 | * @see cxListInsert() |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
589 | * @see cxListInsertAfter() |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
590 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
591 | cx_attr_nonnull |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
592 | static inline int cxListInsertBefore( |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
593 | CxIterator *iter, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
594 | const void *elem |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
595 | ) { |
1201
84fc692d2708
fix list.h was not includable by C++
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1193
diff
changeset
|
596 | CxList* list = (CxList*)iter->src_handle.m; |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
597 | list->collection.sorted = false; |
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
598 | return list->cl->insert_iter(iter, elem, 1); |
499
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
599 | } |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
600 | |
3dc9075df822
add cxListInsertAfter() and cxListInsertBefore()
Mike Becker <universe@uap-core.de>
parents:
495
diff
changeset
|
601 | /** |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
602 | * 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
|
603 | * |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
604 | * 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
|
605 | * removing the element. |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
606 | * |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
607 | * @param list the list |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
608 | * @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
|
609 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
610 | * @retval non-zero index out of bounds |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
611 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
612 | cx_attr_nonnull |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
613 | static inline int cxListRemove( |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
614 | CxList *list, |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
615 | size_t index |
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
616 | ) { |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
617 | return list->cl->remove(list, index, 1, NULL) == 0; |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
618 | } |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
619 | |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
620 | /** |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
621 | * 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
|
622 | * |
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
|
623 | * 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
|
624 | * @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
|
625 | * 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
|
626 | * |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
627 | * @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
|
628 | * @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
|
629 | * @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
|
630 | * @retval zero success |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
631 | * @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
|
632 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
633 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
634 | cx_attr_access_w(3) |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
635 | static inline int cxListRemoveAndGet( |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
636 | CxList *list, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
637 | size_t index, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
638 | void *targetbuf |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
639 | ) { |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
640 | return list->cl->remove(list, index, 1, targetbuf) == 0; |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
641 | } |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
642 | |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
643 | /** |
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
|
644 | * 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
|
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 | * 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
|
647 | * @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
|
648 | * 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
|
649 | * |
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 | * @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
|
651 | * @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
|
652 | * @retval zero success |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
653 | * @retval non-zero 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
|
654 | * @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
|
655 | * @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
|
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 | cx_attr_nonnull |
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 | cx_attr_access_w(2) |
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 | static inline int 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 | CxList *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
|
661 | void *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
|
662 | ) { |
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 | return list->cl->remove(list, 0, 1, targetbuf) == 0; |
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 | |
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 | /** |
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 | * 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
|
668 | * |
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 | * 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
|
670 | * |
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 | * 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
|
672 | * @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
|
673 | * 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
|
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 | * @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
|
676 | * @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
|
677 | * @retval zero success |
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 | * @retval non-zero 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
|
679 | * @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
|
680 | * @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
|
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 | #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
|
683 | |
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 | |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
685 | /** |
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 | * 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
|
687 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
688 | * 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
|
689 | * @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
|
690 | * 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
|
691 | * |
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 | * @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
|
693 | * @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
|
694 | * @retval zero success |
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 | * @retval non-zero 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
|
696 | */ |
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 | cx_attr_nonnull |
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 | cx_attr_access_w(2) |
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 | static inline int 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
|
700 | CxList *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
|
701 | void *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
|
702 | ) { |
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 | // note: index may wrap - member function will catch that |
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 | return list->cl->remove(list, list->collection.size - 1, 1, targetbuf) == 0; |
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 | |
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 | * 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
|
709 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
710 | * 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
|
711 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
712 | * 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
|
713 | * @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
|
714 | * 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
|
715 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
716 | * @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
|
717 | * @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
|
718 | * @retval zero success |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
719 | * @retval non-zero 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
|
720 | * @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
|
721 | * @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
|
722 | */ |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
723 | #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
|
724 | |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
725 | /** |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
726 | * 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
|
727 | * |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
728 | * 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
|
729 | * 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
|
730 | * 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
|
731 | * 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
|
732 | * 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
|
733 | * 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
|
734 | * |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
735 | * @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
|
736 | * @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
|
737 | * @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
|
738 | * @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
|
739 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
740 | cx_attr_nonnull |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
741 | static inline size_t cxListRemoveArray( |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
742 | CxList *list, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
743 | size_t index, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
744 | size_t num |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
745 | ) { |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
746 | return list->cl->remove(list, index, num, NULL); |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
747 | } |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
748 | |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
749 | /** |
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
|
750 | * 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
|
751 | * |
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
|
752 | * 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
|
753 | * @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
|
754 | * 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
|
755 | * |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
756 | * @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
|
757 | * @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
|
758 | * @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
|
759 | * @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
|
760 | * @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
|
761 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
762 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
763 | cx_attr_access_w(4) |
919
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
764 | static inline size_t cxListRemoveArrayAndGet( |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
765 | CxList *list, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
766 | size_t index, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
767 | size_t num, |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
768 | void *targetbuf |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
769 | ) { |
75da57d4634e
add possibility to remove arrays of data and retrieve removed data
Mike Becker <universe@uap-core.de>
parents:
892
diff
changeset
|
770 | return list->cl->remove(list, index, num, targetbuf); |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
771 | } |
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
772 | |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
773 | /** |
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
774 | * 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
|
775 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
776 | * 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
|
777 | * element before removing them. |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
778 | * |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
779 | * @param list the list |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
780 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
781 | cx_attr_nonnull |
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
782 | static inline void cxListClear(CxList *list) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
783 | list->collection.sorted = true; // empty lists are always sorted |
664
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
784 | list->cl->clear(list); |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
785 | } |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
786 | |
af5bf4603a5d
add cxListClear and fix missing destructor invocations - #241 #246
Mike Becker <universe@uap-core.de>
parents:
655
diff
changeset
|
787 | /** |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
788 | * 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
|
789 | * |
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
|
790 | * Implementations should only allocate temporary memory for the swap if |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
791 | * it is necessary. |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
792 | * |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
793 | * @param list the list |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
794 | * @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
|
795 | * @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
|
796 | * @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
|
797 | * @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
|
798 | * or the swap needed extra memory, but allocation failed |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
799 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
800 | cx_attr_nonnull |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
801 | static inline int cxListSwap( |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
802 | CxList *list, |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
803 | size_t i, |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
804 | size_t j |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
805 | ) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
806 | list->collection.sorted = false; |
647
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
807 | return list->cl->swap(list, i, j); |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
808 | } |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
809 | |
2e6e9d9f2159
implement swap function for list elements - fixes #218
Mike Becker <universe@uap-core.de>
parents:
641
diff
changeset
|
810 | /** |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
811 | * 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
|
812 | * |
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
|
813 | * 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
|
814 | * |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
815 | * @param list the list |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
816 | * @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
|
817 | * @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
|
818 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
819 | cx_attr_nonnull |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
820 | static inline void *cxListAt( |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
821 | const CxList *list, |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
822 | size_t index |
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
823 | ) { |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
824 | return list->cl->at(list, index); |
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
825 | } |
439
9a5adedd6de6
add high-level function cxListAt()
Mike Becker <universe@uap-core.de>
parents:
438
diff
changeset
|
826 | |
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
|
827 | /** |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
828 | * 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
|
829 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
830 | * 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
|
831 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
832 | * @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
|
833 | * @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
|
834 | */ |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
835 | cx_attr_nonnull |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
836 | static inline void *cxListFirst(const CxList *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
|
837 | return list->cl->at(list, 0); |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
838 | } |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
839 | |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
840 | /** |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
841 | * 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
|
842 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
843 | * 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
|
844 | * |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
845 | * @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
|
846 | * @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
|
847 | */ |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
848 | cx_attr_nonnull |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
849 | static inline void *cxListLast(const CxList *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
|
850 | return list->cl->at(list, list->collection.size - 1); |
b4c3e0b4c3d5
add convenience functions for easy access to first/last element of a list
Mike Becker <universe@uap-core.de>
parents:
1305
diff
changeset
|
851 | } |
1287
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
852 | |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
853 | /** |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
854 | * Sets the element at the specified index in the list |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
855 | * |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
856 | * @param list the list to set the element in |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
857 | * @param index the index to set the element at |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
858 | * @param elem element to set |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
859 | * @retval zero on success |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
860 | * @retval non-zero when index is out of bounds |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
861 | */ |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
862 | cx_attr_nonnull |
1289
2e8edba252a0
fixes missing cx_attr_export - relates to #642
Mike Becker <universe@uap-core.de>
parents:
1287
diff
changeset
|
863 | cx_attr_export |
1287
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
864 | int cxListSet( |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
865 | CxList *list, |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
866 | size_t index, |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
867 | const void *elem |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
868 | ); |
3a3ffc27813f
adds cxListSet() - resolves #642
Mike Becker <universe@uap-core.de>
parents:
1239
diff
changeset
|
869 | |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
870 | /** |
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
871 | * 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
|
872 | * |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
873 | * The returned iterator is position-aware. |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
874 | * |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
875 | * If the index is out of range, a past-the-end iterator will be returned. |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
876 | * |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
877 | * @param list the list |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
878 | * @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
|
879 | * @return a new iterator |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
880 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
881 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
882 | cx_attr_nodiscard |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
883 | static inline CxIterator cxListIteratorAt( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
884 | const CxList *list, |
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
885 | size_t index |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
886 | ) { |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
887 | return list->cl->iterator(list, index, false); |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
888 | } |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
889 | |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
890 | /** |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
891 | * 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:
647
diff
changeset
|
892 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
893 | * The returned iterator is position-aware. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
894 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
895 | * If the index is out of range, a past-the-end iterator will be returned. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
896 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
897 | * @param list the list |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
898 | * @param index the index where the iterator shall point at |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
899 | * @return a new iterator |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
900 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
901 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
902 | cx_attr_nodiscard |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
903 | static inline CxIterator cxListBackwardsIteratorAt( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
904 | const CxList *list, |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
905 | size_t index |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
906 | ) { |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
907 | return list->cl->iterator(list, index, true); |
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
908 | } |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
909 | |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
910 | /** |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
911 | * Returns a mutating iterator pointing to the item at the specified index. |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
912 | * |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
913 | * The returned iterator is position-aware. |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
914 | * |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
915 | * If the index is out of range, a past-the-end iterator will be returned. |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
916 | * |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
917 | * @param list the list |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
918 | * @param index the index where the iterator shall point at |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
919 | * @return a new iterator |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
920 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
921 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
922 | cx_attr_nodiscard |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
923 | cx_attr_export |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
924 | CxIterator cxListMutIteratorAt( |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
925 | CxList *list, |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
926 | size_t index |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
927 | ); |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
928 | |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
929 | /** |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
930 | * Returns a mutating backwards iterator pointing to the item at the |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
931 | * specified index. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
932 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
933 | * The returned iterator is position-aware. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
934 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
935 | * If the index is out of range, a past-the-end iterator will be returned. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
936 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
937 | * @param list the list |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
938 | * @param index the index where the iterator shall point at |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
939 | * @return a new iterator |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
940 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
941 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
942 | cx_attr_nodiscard |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
943 | cx_attr_export |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
944 | CxIterator cxListMutBackwardsIteratorAt( |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
945 | CxList *list, |
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
946 | size_t index |
640
55cc3b373c5e
simplify list class - fixes #236
Mike Becker <universe@uap-core.de>
parents:
638
diff
changeset
|
947 | ); |
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
948 | |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
949 | /** |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
950 | * 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
|
951 | * |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
952 | * The returned iterator is position-aware. |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
953 | * |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
954 | * 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
|
955 | * |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
956 | * @param list the list |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
957 | * @return a new iterator |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
958 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
959 | cx_attr_nodiscard |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
960 | static inline CxIterator cxListIterator(const CxList *list) { |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
961 | if (list == NULL) list = cxEmptyList; |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
962 | return list->cl->iterator(list, 0, false); |
494
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
963 | } |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
964 | |
6ce8cfa10a96
add iterator interface + linked list iterator
Mike Becker <universe@uap-core.de>
parents:
490
diff
changeset
|
965 | /** |
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
966 | * Returns a mutating iterator pointing to the first item of the list. |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
967 | * |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
968 | * The returned iterator is position-aware. |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
969 | * |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
970 | * If the list is empty or @c NULL, a past-the-end iterator will be returned. |
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
971 | * |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
972 | * @param list the list |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
973 | * @return a new iterator |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
974 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
975 | cx_attr_nodiscard |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
976 | static inline CxIterator cxListMutIterator(CxList *list) { |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
977 | if (list == NULL) list = cxEmptyList; |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
978 | return cxListMutIteratorAt(list, 0); |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
979 | } |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
980 | |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
981 | |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
982 | /** |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
983 | * 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:
647
diff
changeset
|
984 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
985 | * The returned iterator is position-aware. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
986 | * |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
987 | * 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:
647
diff
changeset
|
988 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
989 | * @param list the list |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
990 | * @return a new iterator |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
991 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
992 | cx_attr_nodiscard |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
993 | static inline CxIterator cxListBackwardsIterator(const CxList *list) { |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
994 | if (list == NULL) list = cxEmptyList; |
856
6bbbf219251d
fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents:
854
diff
changeset
|
995 | return list->cl->iterator(list, list->collection.size - 1, true); |
655
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
996 | } |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
997 | |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
998 | /** |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
999 | * Returns a mutating backwards iterator pointing to the last item of the list. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
1000 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
1001 | * The returned iterator is position-aware. |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
1002 | * |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
1003 | * 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:
647
diff
changeset
|
1004 | * |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
1005 | * @param list the list |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
1006 | * @return a new iterator |
7340c4255f1f
implement backwards iterator - fixes #238
Mike Becker <universe@uap-core.de>
parents:
647
diff
changeset
|
1007 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1008 | cx_attr_nodiscard |
853
d4baf4dd55c3
simplify iterator structures
Mike Becker <universe@uap-core.de>
parents:
764
diff
changeset
|
1009 | static inline CxIterator cxListMutBackwardsIterator(CxList *list) { |
1305
c34a72d8e104
some cxListIterator() variants now also allow NULL lists
Mike Becker <universe@uap-core.de>
parents:
1293
diff
changeset
|
1010 | if (list == NULL) list = cxEmptyList; |
856
6bbbf219251d
fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents:
854
diff
changeset
|
1011 | return cxListMutBackwardsIteratorAt(list, list->collection.size - 1); |
630
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
1012 | } |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
1013 | |
ac5e7f789048
separate iterators and mutating iterators
Mike Becker <universe@uap-core.de>
parents:
629
diff
changeset
|
1014 | /** |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1015 | * 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
|
1016 | * |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
1017 | * 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
|
1018 | * |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
1019 | * @param list the list |
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
1020 | * @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
|
1021 | * @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
|
1022 | * @see cxListIndexValid() |
1293
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1023 | * @see cxListContains() |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
1024 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1025 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1026 | cx_attr_nodiscard |
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1027 | static inline size_t cxListFind( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
1028 | const CxList *list, |
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
1029 | const void *elem |
489
af6be1e123aa
add some const qualifiers
Mike Becker <universe@uap-core.de>
parents:
488
diff
changeset
|
1030 | ) { |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1031 | return list->cl->find_remove((CxList*)list, elem, false); |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1032 | } |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1033 | |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1034 | /** |
1293
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1035 | * Checks, if the list contains the specified element. |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1036 | * |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1037 | * 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
|
1038 | * |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1039 | * @param list the list |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1040 | * @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
|
1041 | * @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
|
1042 | * @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
|
1043 | * @see cxListFind() |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1044 | */ |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1045 | cx_attr_nonnull |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1046 | cx_attr_nodiscard |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1047 | static inline bool cxListContains( |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1048 | const CxList* list, |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1049 | const void* elem |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1050 | ) { |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1051 | return list->cl->find_remove((CxList*)list, elem, false) < list->collection.size; |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1052 | } |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1053 | |
a8d86a951d0b
adds cxListContains() implementation (still needs test and docu)
Mike Becker <universe@uap-core.de>
parents:
1289
diff
changeset
|
1054 | /** |
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1055 | * 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
|
1056 | * |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1057 | * @param list the list |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1058 | * @param index the index |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1059 | * @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
|
1060 | * @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
|
1061 | */ |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1062 | cx_attr_nonnull |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1063 | cx_attr_nodiscard |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1064 | static inline bool cxListIndexValid(const CxList *list, size_t index) { |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1065 | return index < list->collection.size; |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1066 | } |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1067 | |
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1068 | /** |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1069 | * 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
|
1070 | * |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1071 | * 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
|
1072 | * |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1073 | * @param list the list |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1074 | * @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
|
1075 | * @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
|
1076 | * 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
|
1077 | * @see cxListIndexValid() |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1078 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1079 | cx_attr_nonnull |
1162
e3bb67b72d33
remove dependency to ssize_t - fixes #552
Mike Becker <universe@uap-core.de>
parents:
1111
diff
changeset
|
1080 | static inline size_t cxListFindRemove( |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1081 | CxList *list, |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
1082 | const void *elem |
764
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1083 | ) { |
ccbdbd088455
add cxListFindRemove and cx_linked_list_find_node
Mike Becker <universe@uap-core.de>
parents:
759
diff
changeset
|
1084 | return list->cl->find_remove(list, elem, true); |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
1085 | } |
398
8d506ed6c1c0
adds first draft for linked list implementation
Mike Becker <universe@uap-core.de>
parents:
393
diff
changeset
|
1086 | |
464
7fafc95968fc
add documentation for list.h
Mike Becker <universe@uap-core.de>
parents:
460
diff
changeset
|
1087 | /** |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1088 | * Sorts the list. |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
1089 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1090 | * @remark The underlying sort algorithm is implementation defined. |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
1091 | * |
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
1092 | * @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
|
1093 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1094 | cx_attr_nonnull |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
1095 | static inline void cxListSort(CxList *list) { |
1239
b4b1f15d1866
complete more than 80% of the list.h documentation
Mike Becker <universe@uap-core.de>
parents:
1201
diff
changeset
|
1096 | if (list->collection.sorted) return; |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
1097 | list->cl->sort(list); |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
1098 | list->collection.sorted = true; |
469
0458bff0b1cd
add high level list sort and inlines method invocation functions
Mike Becker <universe@uap-core.de>
parents:
464
diff
changeset
|
1099 | } |
404 | 1100 | |
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
1101 | /** |
490 | 1102 | * Reverses the order of the items. |
1103 | * | |
1104 | * @param list the list | |
1105 | */ | |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1106 | cx_attr_nonnull |
500
eb9e7bd40a8e
do not hide pointers behind typedefs
Mike Becker <universe@uap-core.de>
parents:
499
diff
changeset
|
1107 | static inline void cxListReverse(CxList *list) { |
1163
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
1108 | // still sorted, but not according to the cmp_func |
68ff0839bc6a
optimize cx_arl_find_remove for sorted arrays - fixes #547
Mike Becker <universe@uap-core.de>
parents:
1162
diff
changeset
|
1109 | list->collection.sorted = false; |
490 | 1110 | list->cl->reverse(list); |
1111 | } | |
1112 | ||
1113 | /** | |
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
1114 | * 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
|
1115 | * |
618
1f5a8f6f3015
#219 array list: implement compare
Mike Becker <universe@uap-core.de>
parents:
528
diff
changeset
|
1116 | * First, the list sizes are compared. |
1f5a8f6f3015
#219 array list: implement compare
Mike Becker <universe@uap-core.de>
parents:
528
diff
changeset
|
1117 | * 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
|
1118 | * |
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
1119 | * @param list the list |
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
1120 | * @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
|
1121 | * @retval zero both lists are equal element wise |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1122 | * @retval negative the first list is smaller |
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1123 | * 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
|
1124 | * @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
|
1125 | * 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
|
1126 | */ |
985
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1127 | cx_attr_nonnull |
68754c7de906
major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents:
919
diff
changeset
|
1128 | cx_attr_nodiscard |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
1129 | cx_attr_export |
618
1f5a8f6f3015
#219 array list: implement compare
Mike Becker <universe@uap-core.de>
parents:
528
diff
changeset
|
1130 | int cxListCompare( |
890
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
1131 | const CxList *list, |
54565fd74e74
move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents:
882
diff
changeset
|
1132 | const CxList *other |
618
1f5a8f6f3015
#219 array list: implement compare
Mike Becker <universe@uap-core.de>
parents:
528
diff
changeset
|
1133 | ); |
488
9138acaa494b
add cxLinkedListFromArray() and cxListCompare()
Mike Becker <universe@uap-core.de>
parents:
484
diff
changeset
|
1134 | |
503
a89857072ace
add new destructor API and apply it to CxList
Mike Becker <universe@uap-core.de>
parents:
500
diff
changeset
|
1135 | /** |
528
4fbfac557df8
#179 improve API for list content destruction
Mike Becker <universe@uap-core.de>
parents:
526
diff
changeset
|
1136 | * 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
|
1137 | * |
1101
2872f287fadc
refine docs for list.h - issue #548
Mike Becker <universe@uap-core.de>
parents:
993
diff
changeset
|
1138 | * 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
|
1139 | * |
993
b642eca4b956
make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents:
985
diff
changeset
|
1140 | * @param list the list which shall be freed |
503
a89857072ace
add new destructor API and apply it to CxList
Mike Becker <universe@uap-core.de>
parents:
500
diff
changeset
|
1141 | */ |
1180
4c3a69b9723a
add support for building windows DLLs - resolves #582
Mike Becker <universe@uap-core.de>
parents:
1163
diff
changeset
|
1142 | cx_attr_export |
1109
89ec23988b88
free functions should not be inline in release mode - relates to #541
Mike Becker <universe@uap-core.de>
parents:
1101
diff
changeset
|
1143 | 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
|
1144 | |
704
35f06c5eeb0e
add empty list implementation - fixes #258
Mike Becker <universe@uap-core.de>
parents:
699
diff
changeset
|
1145 | |
415 | 1146 | #ifdef __cplusplus |
628
1e2be40f0cb5
use //-style single line comments everywhere
Mike Becker <universe@uap-core.de>
parents:
621
diff
changeset
|
1147 | } // extern "C" |
415 | 1148 | #endif |
1149 | ||
628
1e2be40f0cb5
use //-style single line comments everywhere
Mike Becker <universe@uap-core.de>
parents:
621
diff
changeset
|
1150 | #endif // UCX_LIST_H |