Skip to content

mori-atsushi/kotlin-cacheable

Repository files navigation

Kotlin Cacheable

Kotlin Cacheable is an annotation-based caching library for Kotlin Multiplatform.

Setup

This library is published to Maven Central. Add the Maven Central repository to your project's pluginManagement and dependencyResolutionManagement sections.

// setting.gradle.kts
pluginManagement {
    repositories {
        mavenCentral()
    }
}
dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.PREFER_PROJECT)
    repositories {
        mavenCentral()
    }
}

Enable the Gradle plugin for the module where you want to use this library.

// build.gradle.kts
plugins {
    kotlin(/* ... */)
    id("com.moriatsushi.cacheable") version "0.0.3"
}

You also need to add the cacheable-core dependency to the module.

// build.gradle.kts
dependencies {
    implementation("com.moriatsushi.cacheable:cacheable-core:0.0.3")
}

Basic Usage

You can use @Cacheable annotation to cache the result of specified functions. When you call a function with this annotation, it will return the cached value if the function is called with the same arguments.

Here is an example:

@Cacheable
fun getSomething(key: String): Something {
    /* ... */
}

This is equivalent to the following code:

private var cache = mutableMapOf<String, Something>()

fun getSomething(key: String): Something =
    cache.getOrPut(key) { /* ... */ }

If you use the cacheable function within a class, the cache is only shared within an instance of the class.

You can also use @Cacheable annotation for a suspend function.

class Repository(private val api: Api) {
    @Cacheable
    suspend fun getUser(id: String): User =
        api.getUser(id)
}

APIs

There are 2 parameters you can specify to @Cacheable annotation.

  • maxCount: The maximum number of cached values. If the number of cached values exceeds this value, the cache with the oldest access time will be removed. If you don't specify this parameter, the number of cached values will be unlimited.
  • lock: When this is true, the function is guaranteed to be called only once even if the function is called multiple times with the same arguments at the same time. Otherwise, the function may be called multiple times with the same arguments at the same time. The default value is false.
class SomeClass {
    @Cacheable(maxCount = 10, lock = true)
    fun getSomething(key: String): Something {
        // ...
    }
}

About

An annotation-based caching library for Kotlin Multiplatform

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages