3 weeks ago
ucx update + fix doc attach/detach + fix ui_set with unbound values
174 | 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 | */ | |
28 | /** | |
440 | 29 | * @file compare.h |
30 | * @brief A collection of simple compare functions. | |
31 | * @author Mike Becker | |
32 | * @author Olaf Wintermann | |
33 | * @copyright 2-Clause BSD License | |
174 | 34 | */ |
35 | ||
36 | #ifndef UCX_COMPARE_H | |
37 | #define UCX_COMPARE_H | |
38 | ||
39 | #include "common.h" | |
40 | ||
41 | #ifdef __cplusplus | |
42 | extern "C" { | |
43 | #endif | |
44 | ||
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
45 | /** |
440 | 46 | * A comparator function comparing two arbitrary values. |
47 | * | |
48 | * All functions from compare.h with the cx_cmp prefix are | |
49 | * compatible with this signature and can be used as | |
50 | * compare function for collections, or other implementations | |
51 | * that need to be type-agnostic. | |
52 | * | |
53 | * For simple comparisons the cx_vcmp family of functions | |
54 | * can be used, but they are NOT compatible with this function | |
55 | * pointer. | |
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
56 | */ |
440 | 57 | cx_attr_nonnull |
58 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
59 | cx_attr_export |
440 | 60 | typedef int (*cx_compare_func)( |
61 | const void *left, | |
62 | const void *right | |
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
63 | ); |
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
64 | |
174 | 65 | /** |
66 | * Compares two integers of type int. | |
67 | * | |
440 | 68 | * @note the parameters deliberately have type @c void* to be |
69 | * compatible with #cx_compare_func without the need of a cast. | |
70 | * | |
174 | 71 | * @param i1 pointer to integer one |
72 | * @param i2 pointer to integer two | |
440 | 73 | * @retval -1 if the left argument is less than the right argument |
74 | * @retval 0 if both arguments are equal | |
75 | * @retval 1 if the left argument is greater than the right argument | |
174 | 76 | */ |
440 | 77 | cx_attr_nonnull |
78 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
79 | cx_attr_export |
324 | 80 | int cx_cmp_int(const void *i1, const void *i2); |
174 | 81 | |
82 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
83 | * Compares two integers of type int. |
440 | 84 | * |
85 | * @param i1 integer one | |
86 | * @param i2 integer two | |
87 | * @retval -1 if the left argument is less than the right argument | |
88 | * @retval 0 if both arguments are equal | |
89 | * @retval 1 if the left argument is greater than the right argument | |
90 | */ | |
91 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
92 | cx_attr_export |
440 | 93 | int cx_vcmp_int(int i1, int i2); |
94 | ||
95 | /** | |
174 | 96 | * Compares two integers of type long int. |
97 | * | |
440 | 98 | * @note the parameters deliberately have type @c void* to be |
99 | * compatible with #cx_compare_func without the need of a cast. | |
100 | * | |
174 | 101 | * @param i1 pointer to long integer one |
102 | * @param i2 pointer to long integer two | |
440 | 103 | * @retval -1 if the left argument is less than the right argument |
104 | * @retval 0 if both arguments are equal | |
105 | * @retval 1 if the left argument is greater than the right argument | |
174 | 106 | */ |
440 | 107 | cx_attr_nonnull |
108 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
109 | cx_attr_export |
324 | 110 | int cx_cmp_longint(const void *i1, const void *i2); |
174 | 111 | |
112 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
113 | * Compares two integers of type long int. |
440 | 114 | * |
115 | * @param i1 long integer one | |
116 | * @param i2 long integer two | |
117 | * @retval -1 if the left argument is less than the right argument | |
118 | * @retval 0 if both arguments are equal | |
119 | * @retval 1 if the left argument is greater than the right argument | |
120 | */ | |
121 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
122 | cx_attr_export |
440 | 123 | int cx_vcmp_longint(long int i1, long int i2); |
124 | ||
125 | /** | |
174 | 126 | * Compares two integers of type long long. |
127 | * | |
440 | 128 | * @note the parameters deliberately have type @c void* to be |
129 | * compatible with #cx_compare_func without the need of a cast. | |
130 | * | |
174 | 131 | * @param i1 pointer to long long one |
132 | * @param i2 pointer to long long two | |
440 | 133 | * @retval -1 if the left argument is less than the right argument |
134 | * @retval 0 if both arguments are equal | |
135 | * @retval 1 if the left argument is greater than the right argument | |
174 | 136 | */ |
440 | 137 | cx_attr_nonnull |
138 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
139 | cx_attr_export |
324 | 140 | int cx_cmp_longlong(const void *i1, const void *i2); |
174 | 141 | |
142 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
143 | * Compares two integers of type long long. |
440 | 144 | * |
145 | * @param i1 long long int one | |
146 | * @param i2 long long int two | |
147 | * @retval -1 if the left argument is less than the right argument | |
148 | * @retval 0 if both arguments are equal | |
149 | * @retval 1 if the left argument is greater than the right argument | |
150 | */ | |
151 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
152 | cx_attr_export |
440 | 153 | int cx_vcmp_longlong(long long int i1, long long int i2); |
154 | ||
155 | /** | |
174 | 156 | * Compares two integers of type int16_t. |
157 | * | |
440 | 158 | * @note the parameters deliberately have type @c void* to be |
159 | * compatible with #cx_compare_func without the need of a cast. | |
160 | * | |
174 | 161 | * @param i1 pointer to int16_t one |
162 | * @param i2 pointer to int16_t two | |
440 | 163 | * @retval -1 if the left argument is less than the right argument |
164 | * @retval 0 if both arguments are equal | |
165 | * @retval 1 if the left argument is greater than the right argument | |
174 | 166 | */ |
440 | 167 | cx_attr_nonnull |
168 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
169 | cx_attr_export |
324 | 170 | int cx_cmp_int16(const void *i1, const void *i2); |
174 | 171 | |
172 | /** | |
440 | 173 | * Compares two integers of type int16_t. |
174 | * | |
175 | * @param i1 int16_t one | |
176 | * @param i2 int16_t two | |
177 | * @retval -1 if the left argument is less than the right argument | |
178 | * @retval 0 if both arguments are equal | |
179 | * @retval 1 if the left argument is greater than the right argument | |
180 | */ | |
181 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
182 | cx_attr_export |
440 | 183 | int cx_vcmp_int16(int16_t i1, int16_t i2); |
184 | ||
185 | /** | |
174 | 186 | * Compares two integers of type int32_t. |
187 | * | |
440 | 188 | * @note the parameters deliberately have type @c void* to be |
189 | * compatible with #cx_compare_func without the need of a cast. | |
190 | * | |
174 | 191 | * @param i1 pointer to int32_t one |
192 | * @param i2 pointer to int32_t two | |
440 | 193 | * @retval -1 if the left argument is less than the right argument |
194 | * @retval 0 if both arguments are equal | |
195 | * @retval 1 if the left argument is greater than the right argument | |
174 | 196 | */ |
440 | 197 | cx_attr_nonnull |
198 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
199 | cx_attr_export |
324 | 200 | int cx_cmp_int32(const void *i1, const void *i2); |
174 | 201 | |
202 | /** | |
440 | 203 | * Compares two integers of type int32_t. |
204 | * | |
205 | * @param i1 int32_t one | |
206 | * @param i2 int32_t two | |
207 | * @retval -1 if the left argument is less than the right argument | |
208 | * @retval 0 if both arguments are equal | |
209 | * @retval 1 if the left argument is greater than the right argument | |
210 | */ | |
211 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
212 | cx_attr_export |
440 | 213 | int cx_vcmp_int32(int32_t i1, int32_t i2); |
214 | ||
215 | /** | |
174 | 216 | * Compares two integers of type int64_t. |
217 | * | |
440 | 218 | * @note the parameters deliberately have type @c void* to be |
219 | * compatible with #cx_compare_func without the need of a cast. | |
220 | * | |
174 | 221 | * @param i1 pointer to int64_t one |
222 | * @param i2 pointer to int64_t two | |
440 | 223 | * @retval -1 if the left argument is less than the right argument |
224 | * @retval 0 if both arguments are equal | |
225 | * @retval 1 if the left argument is greater than the right argument | |
174 | 226 | */ |
440 | 227 | cx_attr_nonnull |
228 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
229 | cx_attr_export |
324 | 230 | int cx_cmp_int64(const void *i1, const void *i2); |
174 | 231 | |
232 | /** | |
440 | 233 | * Compares two integers of type int64_t. |
234 | * | |
235 | * @param i1 int64_t one | |
236 | * @param i2 int64_t two | |
237 | * @retval -1 if the left argument is less than the right argument | |
238 | * @retval 0 if both arguments are equal | |
239 | * @retval 1 if the left argument is greater than the right argument | |
240 | */ | |
241 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
242 | cx_attr_export |
440 | 243 | int cx_vcmp_int64(int64_t i1, int64_t i2); |
244 | ||
245 | /** | |
174 | 246 | * Compares two integers of type unsigned int. |
247 | * | |
440 | 248 | * @note the parameters deliberately have type @c void* to be |
249 | * compatible with #cx_compare_func without the need of a cast. | |
250 | * | |
174 | 251 | * @param i1 pointer to unsigned integer one |
252 | * @param i2 pointer to unsigned integer two | |
440 | 253 | * @retval -1 if the left argument is less than the right argument |
254 | * @retval 0 if both arguments are equal | |
255 | * @retval 1 if the left argument is greater than the right argument | |
174 | 256 | */ |
440 | 257 | cx_attr_nonnull |
258 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
259 | cx_attr_export |
324 | 260 | int cx_cmp_uint(const void *i1, const void *i2); |
174 | 261 | |
262 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
263 | * Compares two integers of type unsigned int. |
440 | 264 | * |
265 | * @param i1 unsigned integer one | |
266 | * @param i2 unsigned integer two | |
267 | * @retval -1 if the left argument is less than the right argument | |
268 | * @retval 0 if both arguments are equal | |
269 | * @retval 1 if the left argument is greater than the right argument | |
270 | */ | |
271 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
272 | cx_attr_export |
440 | 273 | int cx_vcmp_uint(unsigned int i1, unsigned int i2); |
274 | ||
275 | /** | |
174 | 276 | * Compares two integers of type unsigned long int. |
277 | * | |
440 | 278 | * @note the parameters deliberately have type @c void* to be |
279 | * compatible with #cx_compare_func without the need of a cast. | |
280 | * | |
174 | 281 | * @param i1 pointer to unsigned long integer one |
282 | * @param i2 pointer to unsigned long integer two | |
440 | 283 | * @retval -1 if the left argument is less than the right argument |
284 | * @retval 0 if both arguments are equal | |
285 | * @retval 1 if the left argument is greater than the right argument | |
174 | 286 | */ |
440 | 287 | cx_attr_nonnull |
288 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
289 | cx_attr_export |
324 | 290 | int cx_cmp_ulongint(const void *i1, const void *i2); |
174 | 291 | |
292 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
293 | * Compares two integers of type unsigned long int. |
440 | 294 | * |
295 | * @param i1 unsigned long integer one | |
296 | * @param i2 unsigned long integer two | |
297 | * @retval -1 if the left argument is less than the right argument | |
298 | * @retval 0 if both arguments are equal | |
299 | * @retval 1 if the left argument is greater than the right argument | |
300 | */ | |
301 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
302 | cx_attr_export |
440 | 303 | int cx_vcmp_ulongint(unsigned long int i1, unsigned long int i2); |
304 | ||
305 | /** | |
174 | 306 | * Compares two integers of type unsigned long long. |
307 | * | |
440 | 308 | * @note the parameters deliberately have type @c void* to be |
309 | * compatible with #cx_compare_func without the need of a cast. | |
310 | * | |
174 | 311 | * @param i1 pointer to unsigned long long one |
312 | * @param i2 pointer to unsigned long long two | |
440 | 313 | * @retval -1 if the left argument is less than the right argument |
314 | * @retval 0 if both arguments are equal | |
315 | * @retval 1 if the left argument is greater than the right argument | |
174 | 316 | */ |
440 | 317 | cx_attr_nonnull |
318 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
319 | cx_attr_export |
324 | 320 | int cx_cmp_ulonglong(const void *i1, const void *i2); |
174 | 321 | |
322 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
323 | * Compares two integers of type unsigned long long. |
440 | 324 | * |
325 | * @param i1 unsigned long long one | |
326 | * @param i2 unsigned long long two | |
327 | * @retval -1 if the left argument is less than the right argument | |
328 | * @retval 0 if both arguments are equal | |
329 | * @retval 1 if the left argument is greater than the right argument | |
330 | */ | |
331 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
332 | cx_attr_export |
440 | 333 | int cx_vcmp_ulonglong(unsigned long long int i1, unsigned long long int i2); |
334 | ||
335 | /** | |
174 | 336 | * Compares two integers of type uint16_t. |
337 | * | |
440 | 338 | * @note the parameters deliberately have type @c void* to be |
339 | * compatible with #cx_compare_func without the need of a cast. | |
340 | * | |
174 | 341 | * @param i1 pointer to uint16_t one |
342 | * @param i2 pointer to uint16_t two | |
440 | 343 | * @retval -1 if the left argument is less than the right argument |
344 | * @retval 0 if both arguments are equal | |
345 | * @retval 1 if the left argument is greater than the right argument | |
174 | 346 | */ |
440 | 347 | cx_attr_nonnull |
348 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
349 | cx_attr_export |
324 | 350 | int cx_cmp_uint16(const void *i1, const void *i2); |
174 | 351 | |
352 | /** | |
440 | 353 | * Compares two integers of type uint16_t. |
354 | * | |
355 | * @param i1 uint16_t one | |
356 | * @param i2 uint16_t two | |
357 | * @retval -1 if the left argument is less than the right argument | |
358 | * @retval 0 if both arguments are equal | |
359 | * @retval 1 if the left argument is greater than the right argument | |
360 | */ | |
361 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
362 | cx_attr_export |
440 | 363 | int cx_vcmp_uint16(uint16_t i1, uint16_t i2); |
364 | ||
365 | /** | |
174 | 366 | * Compares two integers of type uint32_t. |
367 | * | |
440 | 368 | * @note the parameters deliberately have type @c void* to be |
369 | * compatible with #cx_compare_func without the need of a cast. | |
370 | * | |
174 | 371 | * @param i1 pointer to uint32_t one |
372 | * @param i2 pointer to uint32_t two | |
440 | 373 | * @retval -1 if the left argument is less than the right argument |
374 | * @retval 0 if both arguments are equal | |
375 | * @retval 1 if the left argument is greater than the right argument | |
174 | 376 | */ |
440 | 377 | cx_attr_nonnull |
378 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
379 | cx_attr_export |
324 | 380 | int cx_cmp_uint32(const void *i1, const void *i2); |
174 | 381 | |
382 | /** | |
440 | 383 | * Compares two integers of type uint32_t. |
384 | * | |
385 | * @param i1 uint32_t one | |
386 | * @param i2 uint32_t two | |
387 | * @retval -1 if the left argument is less than the right argument | |
388 | * @retval 0 if both arguments are equal | |
389 | * @retval 1 if the left argument is greater than the right argument | |
390 | */ | |
391 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
392 | cx_attr_export |
440 | 393 | int cx_vcmp_uint32(uint32_t i1, uint32_t i2); |
394 | ||
395 | /** | |
174 | 396 | * Compares two integers of type uint64_t. |
397 | * | |
440 | 398 | * @note the parameters deliberately have type @c void* to be |
399 | * compatible with #cx_compare_func without the need of a cast. | |
400 | * | |
174 | 401 | * @param i1 pointer to uint64_t one |
402 | * @param i2 pointer to uint64_t two | |
440 | 403 | * @retval -1 if the left argument is less than the right argument |
404 | * @retval 0 if both arguments are equal | |
405 | * @retval 1 if the left argument is greater than the right argument | |
174 | 406 | */ |
440 | 407 | cx_attr_nonnull |
408 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
409 | cx_attr_export |
324 | 410 | int cx_cmp_uint64(const void *i1, const void *i2); |
174 | 411 | |
412 | /** | |
440 | 413 | * Compares two integers of type uint64_t. |
414 | * | |
415 | * @param i1 uint64_t one | |
416 | * @param i2 uint64_t two | |
417 | * @retval -1 if the left argument is less than the right argument | |
418 | * @retval 0 if both arguments are equal | |
419 | * @retval 1 if the left argument is greater than the right argument | |
420 | */ | |
421 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
422 | cx_attr_export |
440 | 423 | int cx_vcmp_uint64(uint64_t i1, uint64_t i2); |
424 | ||
425 | /** | |
174 | 426 | * Compares two real numbers of type float with precision 1e-6f. |
427 | * | |
440 | 428 | * @note the parameters deliberately have type @c void* to be |
429 | * compatible with #cx_compare_func without the need of a cast. | |
430 | * | |
174 | 431 | * @param f1 pointer to float one |
432 | * @param f2 pointer to float two | |
440 | 433 | * @retval -1 if the left argument is less than the right argument |
434 | * @retval 0 if both arguments are equal | |
435 | * @retval 1 if the left argument is greater than the right argument | |
174 | 436 | */ |
440 | 437 | cx_attr_nonnull |
438 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
439 | cx_attr_export |
440 | 440 | int cx_cmp_float(const void *f1, const void *f2); |
174 | 441 | |
440 | 442 | /** |
443 | * Compares two real numbers of type float with precision 1e-6f. | |
444 | * | |
445 | * @param f1 float one | |
446 | * @param f2 float two | |
447 | * @retval -1 if the left argument is less than the right argument | |
448 | * @retval 0 if both arguments are equal | |
449 | * @retval 1 if the left argument is greater than the right argument | |
450 | */ | |
451 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
452 | cx_attr_export |
440 | 453 | int cx_vcmp_float(float f1, float f2); |
174 | 454 | |
455 | /** | |
456 | * Compares two real numbers of type double with precision 1e-14. | |
457 | * | |
440 | 458 | * @note the parameters deliberately have type @c void* to be |
459 | * compatible with #cx_compare_func without the need of a cast. | |
460 | * | |
174 | 461 | * @param d1 pointer to double one |
462 | * @param d2 pointer to double two | |
440 | 463 | * @retval -1 if the left argument is less than the right argument |
464 | * @retval 0 if both arguments are equal | |
465 | * @retval 1 if the left argument is greater than the right argument | |
174 | 466 | */ |
440 | 467 | cx_attr_nonnull |
468 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
469 | cx_attr_export |
440 | 470 | int cx_cmp_double(const void *d1, const void *d2); |
471 | ||
472 | /** | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
473 | * Compares two real numbers of type double with precision 1e-14. |
440 | 474 | * |
475 | * @param d1 double one | |
476 | * @param d2 double two | |
477 | * @retval -1 if the left argument is less than the right argument | |
478 | * @retval 0 if both arguments are equal | |
479 | * @retval 1 if the left argument is greater than the right argument | |
480 | */ | |
481 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
482 | cx_attr_export |
440 | 483 | int cx_vcmp_double(double d1, double d2); |
174 | 484 | |
485 | /** | |
486 | * Compares the integer representation of two pointers. | |
487 | * | |
440 | 488 | * @note the parameters deliberately have type @c void* to be |
489 | * compatible with #cx_compare_func without the need of a cast. | |
490 | * | |
324 | 491 | * @param ptr1 pointer to pointer one (const intptr_t*) |
492 | * @param ptr2 pointer to pointer two (const intptr_t*) | |
440 | 493 | * @retval -1 if the left argument is less than the right argument |
494 | * @retval 0 if both arguments are equal | |
495 | * @retval 1 if the left argument is greater than the right argument | |
174 | 496 | */ |
440 | 497 | cx_attr_nonnull |
498 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
499 | cx_attr_export |
440 | 500 | int cx_cmp_intptr(const void *ptr1, const void *ptr2); |
501 | ||
502 | /** | |
503 | * Compares the integer representation of two pointers. | |
504 | * | |
505 | * @param ptr1 pointer one | |
506 | * @param ptr2 pointer two | |
507 | * @retval -1 if the left argument is less than the right argument | |
508 | * @retval 0 if both arguments are equal | |
509 | * @retval 1 if the left argument is greater than the right argument | |
510 | */ | |
511 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
512 | cx_attr_export |
440 | 513 | int cx_vcmp_intptr(intptr_t ptr1, intptr_t ptr2); |
174 | 514 | |
515 | /** | |
516 | * Compares the unsigned integer representation of two pointers. | |
517 | * | |
440 | 518 | * @note the parameters deliberately have type @c void* to be |
519 | * compatible with #cx_compare_func without the need of a cast. | |
520 | * | |
324 | 521 | * @param ptr1 pointer to pointer one (const uintptr_t*) |
522 | * @param ptr2 pointer to pointer two (const uintptr_t*) | |
440 | 523 | * @retval -1 if the left argument is less than the right argument |
524 | * @retval 0 if both arguments are equal | |
525 | * @retval 1 if the left argument is greater than the right argument | |
174 | 526 | */ |
440 | 527 | cx_attr_nonnull |
528 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
529 | cx_attr_export |
440 | 530 | int cx_cmp_uintptr(const void *ptr1, const void *ptr2); |
531 | ||
532 | /** | |
533 | * Compares the unsigned integer representation of two pointers. | |
534 | * | |
535 | * @param ptr1 pointer one | |
536 | * @param ptr2 pointer two | |
537 | * @retval -1 if the left argument is less than the right argument | |
538 | * @retval 0 if both arguments are equal | |
539 | * @retval 1 if the left argument is greater than the right argument | |
540 | */ | |
541 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
542 | cx_attr_export |
440 | 543 | int cx_vcmp_uintptr(uintptr_t ptr1, uintptr_t ptr2); |
174 | 544 | |
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
545 | /** |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
546 | * Compares the pointers specified in the arguments without dereferencing. |
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
547 | * |
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
548 | * @param ptr1 pointer one |
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
549 | * @param ptr2 pointer two |
440 | 550 | * @retval -1 if the left argument is less than the right argument |
551 | * @retval 0 if both arguments are equal | |
552 | * @retval 1 if the left argument is greater than the right argument | |
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
553 | */ |
440 | 554 | cx_attr_nonnull |
555 | cx_attr_nodiscard | |
471
063a9f29098c
ucx update + fix doc attach/detach + fix ui_set with unbound values
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
440
diff
changeset
|
556 | cx_attr_export |
440 | 557 | int cx_cmp_ptr(const void *ptr1, const void *ptr2); |
253
087cc9216f28
initial newapi GTK port
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
174
diff
changeset
|
558 | |
174 | 559 | #ifdef __cplusplus |
560 | } // extern "C" | |
561 | #endif | |
562 | ||
563 | #endif //UCX_COMPARE_H |