Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mori-atsushi/koject
DI Container library for Kotlin Multiplatform.
https://github.com/mori-atsushi/koject
android di-container kotlin kotlin-js kotlin-multiplatform kotlin-native
Last synced: 2 months ago
JSON representation
DI Container library for Kotlin Multiplatform.
- Host: GitHub
- URL: https://github.com/mori-atsushi/koject
- Owner: mori-atsushi
- License: apache-2.0
- Created: 2023-02-22T14:30:38.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-16T20:12:21.000Z (3 months ago)
- Last Synced: 2024-10-18T19:24:53.215Z (3 months ago)
- Topics: android, di-container, kotlin, kotlin-js, kotlin-multiplatform, kotlin-native
- Language: Kotlin
- Homepage: https://mori-atsushi.github.io/koject/
- Size: 5.41 MB
- Stars: 122
- Watchers: 5
- Forks: 3
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-kotlin-multiplatform - Koject - DI Container library for Kotlin Multiplatform. (Libraries / DI)
- kmp-awesome - Koject - KSP DI framework (Libraries / 💉 Dependency Injection)
README
# Koject
[![](https://img.shields.io/badge/Kotlin-Multiplatform-%237f52ff?logo=kotlin)](https://kotlinlang.org/docs/multiplatform.html)
[![](https://img.shields.io/maven-central/v/com.moriatsushi.koject/koject-core)](https://mvnrepository.com/artifact/com.moriatsushi.koject/koject-core)
[![](https://img.shields.io/github/license/mori-atsushi/koject)](https://github.com/Mori-Atsushi/koject/blob/main/LICENSE)Koject is a DI Container Library for Kolin Multiplatform using KSP.
```kotlin
fun main() {
Koject.start()val controller = inject()
}@Singleton
@Provides
class Api@Singleton
@Provides
fun provideDB(): DB {
return DB.create()
}@Binds
@Singleton
@Provides
class RepositoryImpl(
private val api: Api,
private val db: DB,
): Repositoryinterface Repository
@Provides
class Controller(
private val repository: Repository
)
```## Features
* Support [Kotlin Multiplatform](https://kotlinlang.org/docs/multiplatform.html)
* Easy provide with annotations
* Check dependency graph at compile time
* Code generation with [KSP](https://github.com/google/ksp)
* Support multi-module project## Documents
* [Setup](https://mori-atsushi.github.io/koject/docs/setup)
* [Core](https://mori-atsushi.github.io/koject/docs/core)
* [Start Koject](https://mori-atsushi.github.io/koject/docs/core/basic)
* [Qualifier](https://mori-atsushi.github.io/koject/docs/core/qualifier)
* [Binds](https://mori-atsushi.github.io/koject/docs/core/binds)
* [Test](https://mori-atsushi.github.io/koject/docs/test)
* [Android](https://mori-atsushi.github.io/koject/docs/android)
* [iOS (KMM)](https://mori-atsushi.github.io/koject/docs/ios)
* [Compose](https://mori-atsushi.github.io/koject/docs/compose)## Examples
* [Koject TODO (KMM)](https://github.com/Mori-Atsushi/koject/tree/main/examples/kmm)
* [Now in Android App with Koject (Android)](https://github.com/mori-atsushi/nowinandroid)## Related libraries
Koject is inspired by the following libraries.* [google/dagger](https://github.com/google/dagger)
* [InsertKoinIO/koin](https://github.com/InsertKoinIO/koin)
* [evant/kotlin-inject](https://github.com/evant/kotlin-inject)
* [mars885/hilt-binder](https://github.com/mars885/hilt-binder)