Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kotlin/kotlinx.collections.immutable

Immutable persistent collections for Kotlin
https://github.com/kotlin/kotlinx.collections.immutable

collections immutable immutable-collections kotlin

Last synced: 6 days ago
JSON representation

Immutable persistent collections for Kotlin

Awesome Lists containing this project

README

        

# Immutable Collections Library for Kotlin

[![Kotlin Alpha](https://kotl.in/badges/alpha.svg)](https://kotlinlang.org/docs/components-stability.html)
[![JetBrains official project](https://jb.gg/badges/official.svg)](https://confluence.jetbrains.com/display/ALL/JetBrains+on+GitHub)
[![GitHub license](https://img.shields.io/github/license/kotlin/kotlinx.collections.immutable)](LICENSE.txt)
[![Build status](https://teamcity.jetbrains.com/guestAuth/app/rest/builds/buildType:(id:KotlinTools_KotlinxCollectionsImmutable_Build_All)/statusIcon.svg)](https://teamcity.jetbrains.com/viewType.html?buildTypeId=KotlinTools_KotlinxCollectionsImmutable_Build_All)
[![Maven Central](https://img.shields.io/maven-central/v/org.jetbrains.kotlinx/kotlinx-collections-immutable.svg?label=Maven%20Central)](https://central.sonatype.com/artifact/org.jetbrains.kotlinx/kotlinx-collections-immutable)

Immutable collection interfaces and implementation prototypes for Kotlin.

This is a multiplatform library providing implementations for `jvm`, `js`, `wasmJs`, `wasmWasi`
and all [targets supported by the Kotlin/Native compiler](https://kotlinlang.org/docs/native-target-support.html).

For further details see the [proposal](proposal.md).

## What's in this library
### Interfaces and implementations

This library provides interfaces for immutable and persistent collections.

#### Immutable collection interfaces

| Interface | Bases
| ----------| -----
| `ImmutableCollection` | `Collection` |
| `ImmutableList` | `ImmutableCollection`, `List` |
| `ImmutableSet` | `ImmutableCollection`, `Set` |
| `ImmutableMap` | `Map` |

#### Persistent collection interfaces

| Interface | Bases
| ----------| -----
| `PersistentCollection` | `ImmutableCollection` |
| `PersistentList` | `PersistentCollection`, `ImmutableList` |
| `PersistentSet` | `PersistentCollection`, `ImmutableSet` |
| `PersistentMap` | `ImmutableMap` |

#### Persistent collection builder interfaces

| Interface | Bases
| ----------| -----
| `PersistentCollection.Builder` | `MutableCollection` |
| `PersistentList.Builder` | `PersistentCollection.Builder`, `MutableList` |
| `PersistentSet.Builder` | `PersistentCollection.Builder`, `MutableSet` |
| `PersistentMap.Builder` | `MutableMap` |

To instantiate an empty persistent collection or a collection with the specified elements use the functions
`persistentListOf`, `persistentSetOf`, and `persistentMapOf`.

The default implementations of `PersistentSet` and `PersistentMap`, which are returned by `persistentSetOf` and `persistentMapOf`,
preserve the element insertion order during iteration. This comes at expense of maintaining more complex data structures.
If the order of elements doesn't matter, the more efficient implementations returned by the functions
`persistentHashSetOf` and `persistentHashMapOf` can be used.

### Operations

#### toImmutableList/Set/Map

Converts a read-only or mutable collection to an immutable one.
If the receiver is already immutable and has the required type, returns it as is.

```kotlin
fun Iterable.toImmutableList(): ImmutableList
fun Iterable.toImmutableSet(): ImmutableSet
```

#### toPersistentList/Set/Map

Converts a read-only or mutable collection to a persistent one.
If the receiver is already persistent and has the required type, returns it as is.
If the receiver is a builder of the required persistent collection type, calls `build` on it and returns the result.

```kotlin
fun Iterable.toPersistentList(): PersistentList
fun Iterable.toPersistentSet(): PersistentSet
```

#### `+` and `-` operators

`plus` and `minus` operators on persistent collections exploit their immutability
and delegate the implementation to the collections themselves.
The operation is performed with persistence in mind: the returned immutable collection may share storage
with the original collection.

```kotlin
val newList = persistentListOf("a", "b") + "c"
// newList is also a PersistentList
```

> **Note:** you need to import these operators from `kotlinx.collections.immutable` package
in order for them to take the precedence over the ones from the
standard library.

```kotlin
import kotlinx.collections.immutable.*
```

#### Mutate

`mutate` extension function simplifies quite common pattern of persistent collection modification:
get a builder, apply some mutating operations on it, transform it back to a persistent collection:

```kotlin
collection.builder().apply { some_actions_on(this) }.build()
```

With `mutate` it transforms to:

```kotlin
collection.mutate { some_actions_on(it) }
```

## Using in your projects

> Note that the library is experimental and the API is subject to change.

The library is published to Maven Central repository.

The library depends on the Kotlin Standard Library of the version at least `1.9.21`.

### Gradle

Add the Maven Central repository:

```groovy
repositories {
mavenCentral()
}
```

Add the library to dependencies of the platform source set, e.g.:

```groovy
kotlin {
sourceSets {
commonMain {
dependencies {
implementation("org.jetbrains.kotlinx:kotlinx-collections-immutable:0.3.8")
}
}
}
}
```

### Maven

The Maven Central repository is available for dependency lookup by default.
Add dependencies (you can also add other modules that you need):

```xml

org.jetbrains.kotlinx
kotlinx-collections-immutable-jvm
0.3.8

```

## Building from source

You can build and install artifacts to maven local with:

gradlew build install