This plugin is in maintenance mode but will continue to receive 1.2 and 1.3 Kotlin releases. JetBrains has deprecated the existing jvm plugin and replaced it with the multiplatform plugin. If you use 1.3.70 or later you'll receive the warning:
The 'org.jetbrains.kotlin.platform.*' plugins are deprecated and will no longer be available in Kotlin 1.4.
Please migrate the project to the 'org.jetbrains.kotlin.multiplatform' plugin.
See: https://kotlinlang.org/docs/reference/building-mpp-with-gradle.html
The multiplatform plugin is a complete migration from the legacy plugin and provides many of the ergonomic features, such as JVM target configuration and Kotlin library version management that this plugin provided. If you have a project that will move to 1.4 once it's released you should migrate to multiplatform.
Provides the Kotlin plugin via the Gradle plugin portal, and adds ergonomic improvements over the default plugin:
- Automatically depends on the standard library
- Allows Kotlin library versions to be omitted, inferring them automatically from the plugin version
- For Kotlin 1.1 and later, sets the
-jvm-targetand uses the jre standard library based on thesourceCompatibility- Use the https://github.com/nebula-plugins/gradle-java-cross-compile-plugin to set the
targetJdkif desired
- Use the https://github.com/nebula-plugins/gradle-java-cross-compile-plugin to set the
- Bundles the
kotlin-allopenandkotlin-noargplugins to allow them to be applied without adding them manually to the classpath
Refer to the Gradle Plugin Portal for instructions on how to apply the main plugin.
The plugin simplifies a basic Kotlin build script to:
plugins {
id 'nebula.kotlin' version '1.3.70'
}
repositories {
mavenCentral()
}plugins {
id 'nebula.kotlin' version '1.3.70'
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.jetbrains.kotlin:kotlin-reflect'
}There are cases were we only want to use kotlin for specific configurations and applying the plugin added stdlib to implementation by default.
Starting on 1.3.70, it is possible to set the default configurations for stdlib via stdlibConfiguration. For example:
plugins {
id 'nebula.kotlin' version '1.3.70'
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.jetbrains.kotlin:kotlin-reflect'
}
configurations {
myConfig
}
nebulaKotlin {
stdlibConfigurations = ["myConfig"]
}If you use kotlin buildscripts:
nebulaKotlin {
stdlibConfigurations.set(listOf("implementation", "testFixturesImplementation"))
}
This plugin will apply our opinions for default version of additional dependencies but won't add stdlib by default
plugins {
id 'nebula.kotlin-nodep' version '1.3.70'
}The version for kotlin-reflect will be automatically set to match the Kotlin version (1.3.70).
- IntelliJ doesn't set the
-jvm-targetcompiler option based on the Java SDK setting for the project, and can cause the compiler inlining failure if it tries to inline classes compiled with Gradle. Configure the JVM target in IntelliJ preferences to avoid this