1 Version 4.0.1 - tbd
2 --------------------------
3
4 * fixes compilation errors when using a C++ compiler and a high warning level
5
6 Version 4.0.0 - 2025-12-31
7 --------------------------
8
9 * adds cx_system_page_size() to allocator.h
10 * adds cx_compare_func2 function pointer that supports compare functions with custom data
11 * adds a new (optional) capacity parameter to cxJsonCreateArr() and cxJsonObjPutArr()
12 * adds cxJsonFromString(), cxJsonToString(), and cxJsonToPrettyString()
13 * adds cxJsonClone()
14 * adds cxJsonCompare()
15 * adds cxMapCompare()
16 * adds line continuation support to CxProperties / CxPropertiesConfig
17 * adds cx_hash_key_as_string()
18 * adds support for CxHashKey pointers in CX_HASH_KEY() and all map functions
19 * adds CX_NULLSTR convenience macro
20 * adds cx_strcast_m()
21 * adds cx_strat()
22 * adds cx_bstr() and cx_bstr_m()
23 * adds cxBufferMaximumCapacity()
24 * adds cxBufferAppendString()
25 * adds CX_BUFFER_DO_NOT_FREE buffer flag
26 * changes the parameter order of cxBufferInit() and cxBufferCreate()
27 * changes cxBufferReserve() to allow reducing the capacity
28 * changes cxBufferTerminate() to automatically shrink the buffer
29 * changes cxBufferTerminate() so that position and size are equal after a successful operation
30 * changes cxBufferPutString() to accept any kind of string that cx_strcast() supports
31 * changes that multiple string.h functions now also automatically apply cx_strcast() where possible
32 * changes the names of cxDefineDestructor() and cxDefineAdvancedDestructor() to
33 cxSetDestructor() and cxSetdvancedDestructor()
34 * changes the name of cxCollectionCompareFunc() to cxSetCompareFunc()
35 * changes the entire low-level array-list API by making it much simpler
36 * changes the tree API towards a more simple design
37 * changes the members of CxJson and CxJsonValue
38 * changes the return value of cxJsonObjIter() to CxMapIterator
39 * changes CxTree structure so that it now inherits CX_COLLECTION_BASE
40 * changes cxPropertiesLoad() to directly load properties from a file to a CxMap
41 * changes cxFreeDefault() from a macro to a function so that it can be used as a simple destructor
42 * fixes cxJsonWrite() incorrectly returning non-zero when strings needed to be escaped
43 * fixes cxJsonNext() incorrectly returning CX_JSON_INCOMPLETE_DATA when the input ends with trailing spaces
44 * fixes critical memory leak when using cxMapFree() on a kv-list that is using destructors
45 * fixes critical use-after-free with keys stored in kv-lists
46 * fixes that overwriting items with cxMapPut() in a kv-list did not work
47 * fixes that cxReallocate(), cxReallocateArray(), cx_reallocate(), and cx_reallocatearray()
48 were not returning zero after freeing the memory when passed a size of zero
49 * fixes that cx_list_default_insert_array() has the wrong nonnull attribute when used for cxListEmplaceArray()
50 * removes the CX_STR() macro and instead makes the cx_str() inlinable
51 * removes the cx_str*_m() functions
52 * removes the sort_members feature from CxJsonWriter
53 * removes the source and sink API from properties.h
54 * removes the flush feature from CxBuffer
55 * removes the ability to remove elements from the iterators created with cxIterator() and cxIteratorPtr()
56 * removes several unnecessary convenience functions
57 * removes the complicated wrapping of pointer lists
58 * removes cxIteratorRef()
59
60 Version 3.2.0 - 2025-11-30
61 --------------------------
62
63 * adds cxMempoolTransfer() and cxMempoolTransferObject()
64 * adds support for different destruction strategies in CxMempool
65 * adds new key-value-based list implementation
66 + adds support for integer keys to CxHashKey
67 * adds support for comparing arbitrary strings without explicit call to cx_strcast()
68 * adds clone, union, difference, and intersection functions for CxList and CxMap
69 * adds cxListContains() and cxMapContains()
70 * adds cxListReserve() and cxListShrink()
71 * adds cxListSet()
72 * adds cxListFirst() and cxListLast()
73 * adds cxListRemoveAndGetFirst() and cxListRemoveAndGetLast(),
74 and corresponding macro aliases cxListPopFront() and cxListPop()
75 * adds cxListEmplace(), cxListEmplaceAt(), cxListEmplaceArray(), cxListEmplaceArrayAt(), and cxMapEmplace()
76 * adds cxListInsertUnique() and cxListInsertUniqueArray()
77 * adds cx_array_insert_unique() and various convenience macros
78 * adds cx_linked_list_insert_unique() and cx_linked_list_insert_unique_chain()
79 * adds cxCollectionCompareFunc() to conveniently set a compare function for a collection
80 without needing to access the base struct manually
81 * adds cxBufferShrink()
82 * adds cxBufferPop()
83 * adds cxTreeSize()
84 * adds CX_PRIstr and CX_SFMT macros for formatting UCX strings
85 * adds cx_strcpy() and cx_strcpy_a()
86 * adds cxJsonArrRemove() and cxJsonObjRemove()
87 * adds cxStdlibAllocator and allows changes of cxDefaultAllocator
88 * improves performance of the CxList array list implementation
89 * changes over-aggressively declaring functions as static inline
90 * changes cx_str() and cx_mutstr() to allow NULL strings
91 * changes cx_strcast() to also accept C-strings as input
92 * changes grow strategy for the memory pool to reduce reallocations
93 * changes grow strategy for CxBuffer, which does now take the page size into account
94 * changes the implementation of cx_strreplacen() for improved efficiency
95 * changes all cxListIterator() and cxMapIterator() families of functions to also accept NULL as argument
96 * changes insert_element member function of CxList to accept NULL source and return a pointer to the inserted element
97 * changes the compare function wrapper for pointer lists so that it no longer invokes the actual compare function for NULL pointers
98 * changes struct cx_array_reallocator_s by replacing the four generic data members with two specifically named members
99 * changes cx_array_reserve() so that it reserves exactly the requested capacity (i.e., without overallocation)
100 * changes all other array functions to perform smart overallocation to avoid too many subsequent allocations
101 * changes that binary search and infimum always report the largest index, and supremum always reports the smallest index
102 when the found element appears more than once in the array
103 * fixes critical memory overflow in the stack-based array reallocator (this unfortunately breaks the function signature)
104 * fixes critical bug in cx_array_insert_sorted() that caused an infinite loop when inserting duplicates
105 * fixes mempool implementation not supporting NULL as argument for realloc
106 * fixes mempool implementation not supporting zero as size for realloc
107 * fixes that the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval()
108 * fixes that starting an iteration in a non-root node incorrectly continues iteration with the siblings of that node
109 * fixes unnecessary allocations in cx_strcat() family of functions
110 * fixes ineffective overflow check in cx_strcat() family of functions
111 * fixes errno value after failing cxBufferSeek() to be consistently EINVAL
112 * fixes implementation of cxBufferTerminate()
113 * fixes that cxBufferWrite() could auto-extend the buffer beyond the configured threshold
114 * fixes allocator arguments for some printf.h functions not being const
115 * fixes that cx_tree_search() did not investigate subtrees with equally good distance
116 * fixes that memory was freed by the wrong allocator in cx_vasprintf_a() when the underlying vsnprintf() failed
117 * removes all functions that create mutating iterators in favor of making all iterators possibly mutating
118 * removes the use of C23 attributes because they don't mix well with GNU attributes in GCC 15
119
120 Version 3.1.0 - 2025-02-11
121 --------------------------
122
123 * adds properties.h
124 * adds tree.h
125 * adds json.h
126 * adds locale-independent string to number conversion functions
127 * adds reallocarray() like functions to allocator.h
128 * adds cxIterator() to create iterators over raw C arrays
129 * adds cxIteratorPtr() to create iterators over raw C pointer arrays
130 * adds cx_array_reallocator() and cx_array_default_reallocator
131 * adds several new array and list functions
132 * adds cxBufferReset()
133 * adds cxBufferAppend()
134 * adds cxBufferEnableFlushing() and cxBufferFlush()
135 * adds CX_BUFFER_COPY_ON_WRITE and CX_BUFFER_COPY_ON_EXTEND flags
136 * adds cxBufferWriteFunc and cxBufferReadFunc function pointers (for convenience)
137 * adds cx_cmp_ptr()
138 * adds cx_vcmp_* family of functions
139 * adds cx_sprintf() and several more variants
140 * adds runtime constants to read out the actual SBO sizes
141 * adds improved version of UCX 2 Test framework (now a self-contained header)
142 * adds cx_nmemb() utility function to common.h
143 * changes that CxMap returns own CxMapIterator to save memory in CxIterator
144 * changes name of cxBasicMempoolCreate() to cxMempoolCreateSimple()
145 * changes all functions, for which there is no dedicated xyz_a variant,
146 to accept NULL as allocator argument (in which case a default allocator will be used)
147 * changes the name of destroy functions that actually free the memory to better indicate their behavior
148 * changes cx_strcat variants to allow handling of ENOMEM
149 * changes cx_strcast() to also accept cxstring (and doing nothing in that case)
150 * changes the behavior of cxBufferSeek() to allow offset zero for SEEK_END
151 * moves cx_compare_func typedef to compare.h
152 * moves cx_szmul() to common.h
153 * moves stream copy functions to new streams.h
154 * removes cx_strupper() and cx_strlower() because they only do the right thing in special cases
155 * removes several *_m variants of functions in string.h in favor of automatic conversion
156 * removes utils.h
157 * removes flag_removal function from iterator
158 * removes cxMapDetach() and makes cxMapRemoveAndGet() compatible with both map variants
159 * removes the API for changing the store_pointer property of collections after their creation
160 * removes CMake
161 * removes GTest dependency
162 * removes flags to disable SBO in tests
163 * removes CX_LINKED_LIST_SWAP_SBO_SIZE (it's not really an optimization for linked lists)
164 * fixes cx_strcmp() and cx_strcasecmp() not being useful for lexicographic ordering
165 * fixes cx_hash_key_cxstr() evaluating the argument twice
166 * fixes critical bug that produced wrong results when comparing lists of different type but same size
167 * ends UCX 2.1 long term support
168
169 Version 3.0.0 - 2023-07-09
170 --------------------------
171
172 * complete redesign from scratch
173 * collections can now store copies of objects and not just pointers
174 * collections are now dynamically implemented
175 * users of the library can specify own implementations of collections that work with the UCX API
176 * low level API for custom lists that do not use the UCX structures
177 * various fixes and improvements
178 * drops some other, rarely used, features
179 * removes testing implementation from the lib
180
181
182 Version 2.1.0 - 2019-12-30
183 --------------------------
184
185 * adds string replace functions
186 * adds set operations for UcxList and UcxMap
187 * adds sstrcaseprefix() and sstrcasesuffix()
188 * improves Doxygen documentation in ucx/string.h
189 * adds UcxArray data type
190 * adds support for CMake builds, but main build system is still autotools
191
192 Version 2.0 - 2018-12-28
193 ------------------------
194
195 * some uncritical bug fixes
196 * overflow of sstrnlen now returns SIZE_MAX instead of zero
197 * adds scstr_t - a const char* variant for sstr_t
198 * renames utility compare functions
199
200 Version 1.1.0 - 2018-05-14
201 --------------------------
202
203 * adds missing 32 bit support to integer overflow checks
204 * adds ucx_buffer_to_sstr() macro
205 * adds ucx_avl_free_content()
206 * adds some more compare and distance functions in utils.h
207 * adds SFMT() and PRIsstr convenience macros
208 * destructor functions for *_free_content() functions are now optional
209
210 Version 1.0.1 - 2018-01-21
211 --------------------------
212
213 * some bug fixes
214 * adds integer overflow checks
215
216 Version 1.0.0 - 2017-10-28
217 --------------------------
218
219 * first stable version of UCX released
220