We want to provide dependency notations for more popular libraries.
Want to contribute some?
Here is what a dependency notation should look like:
@file:Suppress("PackageDirectoryMismatch", "SpellCheckingInspection", "unused") // 1
import de.fayard.refreshVersions.core.DependencyGroup
import org.gradle.api.Incubating
import org.gradle.kotlin.dsl.IsNotADependency
/** // 2
* painless Kotlin dependency injection
*
* - [Official website here](https://kodein.org/di/)
* - GitHub page: [Kodein-Framework/Kodein-DI](https://github.com/Kodein-Framework/Kodein-DI)
* - [GitHub Releases here](https://github.com/Kodein-Framework/Kodein-DI/releases)
*/
@Incubating
object Kodein : IsNotADependency { // 3
val di = DI // 4
object DI : DependencyGroup( // 5
group = "org.kodein.di", // 6
usePlatformConstraints = false, // 7
rawRule = """
org.kodein.di:kodein-di(-*)
^^^^^^^^^
""".trimIndent() // 8
) {
val bom = module("kodein-bom", isBom = true) // 9
val js = module("kodein-di-js") // 10
val androidx = module("kodein-di-framework-android-x")
}
}
What you need to know:
- We use no package on purpose - and suppress the corresponding warning - so that users don't have to import the dependency notation.
- We provide a KDoc with a description of what the library does, a link to GitHub, and a link to the documentation. Please, keep the exact same style for consistency.
- We tag the objects with
IsNotADependency
, so that the IDE shows an error if the user tries to doimplementation(Kodein)
. - We support Gradle build scripts in both Kotlin and Groovy.
Kodein.DI
works in Kotlin, but not in Groovy. That's why we have the propertyKotlin.di
, which works in both. - We use the base class
DependencyGroup
to define a group of dependency notations. Note that this class also has theIsNotADependency
marker interface. If you want the object or sub-group to be a dependency notation itself, use theDependencyNotationAndGroup
class instead. - The maven group that will be used for all the modules of this
DependencyGroup
(orDependencyNotationAndGroup
). - If the library provides a Bill of Materials (BoM for short), or another kind of platform constraints that should always be used, we set
usePlatformConstraints = true
. (As you can see, in the case of the example, it's not made mandatory.) - All dependency notations with a name like
org.kodein.di:kodein-di(-*)
will use the same versionversion.kodein.di
because we defined an artifact rule. To learn more about those rules, have a look here. DependencyGroup
andDependencyNotationAndGroup
have first class support for BoMs via theisBom = true
parameter. It sets the booleanusePlatformConstraints
totrue
for the group and does various checks.- A module is defined via the
= module("module.name")
syntax.
Three more things before you start coding:
- Look at
Square
,COIL
,Http4K
,Spring
,Kodein
, and others for inspiration. - Try to not forget any artifact!. One of the best ways to do that is to open an issue in the project of the library for which you contribute dependency notations.
- Run the unit tests! There are multiple checks that are done to prevent the most common mistakes.