Releases: Kotlin/kotlinx.collections.immutable
Releases Β· Kotlin/kotlinx.collections.immutable
v0.3.8
v0.3.7
- Upgrade Kotlin version up to 1.9.21
- Support wasmJs and wasmWasi targets
v0.3.6
- Upgrade Kotlin version up to 1.9.0
- Support all targets currently supported by the K/N compiler
- Drop support for the Legacy js target
v0.3.5
v0.3.4
- Upgrade Kotlin version up to 1.4.30
- Publish the library to Maven Central instead of Bintray #96.
- Add license information to published POMs #98.
- Implement workaround for specialized MutableEntrySet.contains/remove KT-41278.
- Bug in PersistentList - list is broken after removeAll call #92.
- Faster bulk operations for non-ordered sets (removeAll, retainAll, containsAll) #91.
- Faster addAll/putAll implementation for non-ordered sets/maps #83.
- Add extension functions to convert Sequence to persistent collections 84.
- Add missing CharSequence.toImmutableSet() extension function.
v0.3.3
v0.3.2
v0.3.1
Update Kotlin version up to 1.3.70
v0.3
- Turn the JVM-only project into a multiplatform library
- JVM artifact id has changed from
kotlinx-collections-immutable
tokotlinx-collections-immutable-jvm
- Builder iterators are fast-fail only on JVM. On the other platforms modifying the builder during iteration not through the corresponding iterator can invalidate the iterator state in an unspecified way.
- In addition to JVM and JS platforms, macosX64, iosX64, iosArm64, iosArm32, linuxX64, and mingwX64 native platforms are supported.
- JVM artifact id has changed from
- Make conversion to persistent collections consistent
toPersistentMap
/Set
always returns an ordered persistent map/settoPersistentHashMap
/Set
always returns an unordered persistent map/settoImmutableMap
/Set
may return any kind of immutable map/set
- Optimize persistent list [builder] batch update operations
addAll(elements)
operation performs ~3 times faster πaddAll(index, elements)
operation takes O(N + M), down from O(N * M), where N is the size of this collection and M - the size of theelements
collection. πremoveAll(elements)
operation takes O(N * K), down from O(N * M), where K is the time complexity ofcontains
operation on theelements
collection πremoveAll(predicate)
operation takes O(N * P), down from O(N * (P + N)), where P is the time complexity of thepredicate
algorithm π
- Implement set/map backing trie canonicalization
add
operation afterremove
operations performs ~20% faster π- iteration after
remove
operations performs ~3 times faster π
v0.2
This release introduces two notable changes.
Split immutable and persistent interfaces
- Immutable collections specify by their contract the real immutability of their implementors
ImmutableCollection
extends read-onlyCollection
ImmutableList
extends read-onlyList
andImmutableCollection
, and overridessubList
method that returnsImmutableList
ImmutableSet
extends read-onlySet
andImmutableCollection
ImmutableMap
extends read-onlyMap
, and overrideskeys
,values
andentries
properties types withImmutableSet
,ImmutableCollection
andImmutableSet
respectively
- Persistent collections extend immutable collections and provide modification operations that return new instances with the modification applied
PersistentCollection
extendsImmutableCollection
, and provides modification operations and builderPersistentList
extendsImmutableList
andPersistentCollection
, and provides modification operationsPersistentSet
extendsImmutableSet
andPersistentCollection
, and provides modification operationsPersistentMap
extendsImmutableMap
, and provides modification operations and builder
plus
,minus
andmutate
extension functions are available only for persistent collections- Deprecate
immutableXOf()
top-level functions and introducepersistentXOf()
toImmutableX()
extension functions returnImmutableX
- Introduce
toPersistentX()
extension functions that returnPersistentX
- Document public API
Replace PCollections-based prototypes with custom performant implementations
PersistentList
implementation is backed by a bit-mapped trie with branching factor of 32add(element: E)
andremoveAt(size - 1)
operations take O(1) time, down from O(log2n) πget
andset
operations take O(log32n), down from O(log2n) (though the same asymptotic) π- Iteration has the same time complexity of O(n), but much faster in practice due to the better reference locality π
- Unordered
PersistentSet
implementation is backed by a hash-array mapped trie (a.k.a. HAMT) with up to 32 children or elements in a nodecontains
,add
andremove
operations take O(log32n) time, down from O(log2n) π- Iteration has the same time complexity of O(n), but much faster in practice due to the better reference locality π
- Unordered
PersistentMap
implementation is backed by a compressed hash-array mapped prefix-tree (a.k.a. CHAMP) with up to 32 children or entries in a nodecontains
,get
,put
andremove
operations take O(log32n) time, down from O(log2n) π- Iteration has the same time complexity of O(n), but much faster in practice due to the better reference locality π
- Ordered
PersistentSet
implementation is backed by the unorderedPersistentMap
which maps elements in this set to next and previous elements in insertion ordercontains
,get
andput
operations take O(log32n) time, down from O(log2n) πremove
operation takes O(log32n) time, down from O(n) π- Iteration takes O(n log32n) time, up from O(n) π
- Ordered
PersistentMap
implementation is backed by the unorderedPersistentMap
which maps keys in this map to values, next and previous keys in insertion ordercontains
,get
andput
operations take O(log32n) time, down from O(log2n) πremove
operation takes O(log32n) time, down from O(n) π- Iteration takes O(n log32n) time, up from O(n) π
- Builders are backed by the same backing storage as the corresponding persistent collections, but apply modifications in-place if the node has already been copied
- Time complexities of all operations are the same as of the corresponding persistent collections. However, avoiding memory allocations leads to significant performance improvement π