为了用 Gradle 构建 Kotlin,你应该设置好 kotlin-gradle 插件,将其应用到你的项目中,并且添加 kotlin-stdlib 依赖。这些操作也可以在 IntelliJ IDEA 中通过调用 Project action 中的 Tools | Kotlin | Configure Kotlin 自动执行。
使用 kotlin-gradle-plugin 编译 Kotlin 源代码和模块.
kotlin-gradle-plugin
要使用的 Kotlin 版本通常定义为 kotlin_version 属性:
kotlin_version
buildscript { ext.kotlin_version = '1.3.11' repositories { mavenCentral() } dependencies { classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" } }
当通过 Gradle 插件 DSL 与 Gradle Kotlin DSL 使用 Kotlin Gradle 插件 1.1.1 及以上版本时,这不是必需的。
Using the kotlin-multiplatform plugin for building multiplatform projects is described in Building Multiplatform Projects with Gradle.
kotlin-multiplatform
针对 JVM,需要应用 Kotlin 插件:
apply plugin: "kotlin"
或者,从 Kotlin 1.1.1 起,可以使用 Gradle 插件 DSL 来应用该插件:
plugins { id "org.jetbrains.kotlin.jvm" version "1.3.11" }
在这个块中的 version 必须是字面值,并且不能从其他构建脚本中应用。
version
对于 Gradle Kotlin DSL,请按以下方式应用插件:
plugins { kotlin("jvm") version "1.3.11" }
Kotlin 源代码可以与同一个文件夹或不同文件夹中的 Java 源代码混用。默认约定是使用不同的文件夹:
project - src - main (root) - kotlin - java
如果不使用默认约定,那么应该更新相应的 sourceSets 属性:
sourceSets { main.kotlin.srcDirs += 'src/main/myKotlin' main.java.srcDirs += 'src/main/myJava' }
对于 Gradle Kotlin DSL,请改用 java.sourceSets { …… } 配置源集。
java.sourceSets { …… }
当针对 JavaScript 时,须应用不同的插件:
apply plugin: "kotlin2js"
这个插件只适用于 Kotlin 文件,因此建议将 Kotlin 和 Java 文件分开(如果是同一项目包含 Java 文件的情况)。与针对 JVM 一样,如果不使用默认约定,我们需要使用 sourceSets 来指定源代码文件夹:
sourceSets { main.kotlin.srcDirs += 'src/main/myKotlin' }
除了输出的 JavaScript 文件,该插件默认会创建一个带二进制描述符的额外 JS 文件。 如果你是构建其他 Kotlin 模块可以依赖的可重用库,那么该文件是必需的,并且应该与转换结果一起分发。 其生成由 kotlinOptions.metaInfo 选项控制:
kotlinOptions.metaInfo
compileKotlin2Js { kotlinOptions.metaInfo = true }
Android 的 Gradle 模型与普通 Gradle 有点不同,所以如果我们要构建一个用 Kotlin 编写的 Android 项目,我们需要用 kotlin-android 插件取代 kotlin 插件:
buildscript { ext.kotlin_version = '1.3.11' …… dependencies { classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" } } apply plugin: 'com.android.application' apply plugin: 'kotlin-android'
不要忘记配置标准库依赖关系。
如果使用 Android Studio,那么需要在 android 下添加以下内容:
android { …… sourceSets { main.java.srcDirs += 'src/main/kotlin' } }
这让 Android Studio 知道该 kotlin 目录是源代码根目录,所以当项目模型加载到 IDE 中时,它会被正确识别。或者,你可以将 Kotlin 类放在 Java 源代码目录中,该目录通常位于 src/main/java。
src/main/java
除了上面显示的 kotlin-gradle-plugin 依赖之外,还需要添加 Kotlin 标准库的依赖:
repositories { mavenCentral() } dependencies { compile "org.jetbrains.kotlin:kotlin-stdlib" }
如果针对 JavaScript,请使用 compile "org.jetbrains.kotlin:kotlin-stdlib-js" 替代之。
compile "org.jetbrains.kotlin:kotlin-stdlib-js"
如果是针对 JDK 7 或 JDK 8,那么可以使用扩展版本的 Kotlin 标准库,其中包含为新版 JDK 增加的额外的扩展函数。使用以下依赖之一来取代 kotlin-stdlib :
kotlin-stdlib
compile "org.jetbrains.kotlin:kotlin-stdlib-jdk7" compile "org.jetbrains.kotlin:kotlin-stdlib-jdk8"
对于 Gradle Kotlin DSL,以下表示法的依赖关系与其等价:
dependencies { compile(kotlin("stdlib")) // 或者以下之一: compile(kotlin("stdlib-jdk7")) compile(kotlin("stdlib-jdk8")) }
在 Kotlin 1.1.x 中,请使用 kotlin-stdlib-jre7 与 kotlin-stdlib-jre8。
kotlin-stdlib-jre7
kotlin-stdlib-jre8
如果你的项目中使用 Kotlin 反射或者测试设施,你也需要添加相应的依赖:
compile "org.jetbrains.kotlin:kotlin-reflect" testCompile "org.jetbrains.kotlin:kotlin-test" testCompile "org.jetbrains.kotlin:kotlin-test-junit"
或者,对于 Gradle Kotlin DSL:
compile(kotlin("reflect")) testCompile(kotlin("test")) testCompile(kotlin("test-junit"))
从 Kotlin 1.1.2 起,使用 org.jetbrains.kotlin group 的依赖项默认使用从已应用的插件获得的版本来解析。你可以用完整的依赖关系符号 (如 compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version",或者在 Gradle Kotlin DSL 中用 kotlin("stdlib", kotlinVersion))手动提供其版本。
org.jetbrains.kotlin
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
kotlin("stdlib", kotlinVersion)
请参见 Kotlin 注解处理工具(kapt)的描述。
kapt
Kotlin 支持 Gradle 中可选的增量编译。 增量编译跟踪构建之间源文件的改动,因此只有受这些改动影响的文件才会被编译。
从 Kotlin 1.1.1 起,默认启用增量编译。
有几种方法来覆盖默认设置:
将 kotlin.incremental=true 或者 kotlin.incremental=false 行添加到一个 gradle.properties 或者一个 local.properties 文件中;
kotlin.incremental=true
kotlin.incremental=false
gradle.properties
local.properties
将 -Pkotlin.incremental=true 或 -Pkotlin.incremental=false 添加到 Gradle 命令行参数。请注意,这样用法中,该参数必须添加到后续每个子构建,并且任何具有禁用增量编译的构建将使增量缓存失效。
-Pkotlin.incremental=true
-Pkotlin.incremental=false
请注意,第一次构建不会是增量的。
Coroutines support is an experimental feature in Kotlin 1.2, so the Kotlin compiler reports a warning when you use coroutines in your project. To turn off the warning, add the following block to your build.gradle file:
build.gradle
kotlin { experimental { coroutines 'enable' } }
Or, with Gradle Kotlin DSL:
import org.jetbrains.kotlin.gradle.dsl.Coroutines // ... kotlin.experimental.coroutines = Coroutines.ENABLE
The Kotlin modules that the build produces are named accordingly to the archivesBaseName property of the project. If a project has a broad name like lib or jvm, which is common for subprojects, the Kotlin output files related to the module (*.kotlin_module) might clash with those from third-party modules with the same name. This causes problems when a project is packaged into a single archive (e.g. APK).
archivesBaseName
lib
jvm
*.kotlin_module
To avoid this, consider setting a unique archivesBaseName manually:
archivesBaseName = 'myExampleProject_lib'
With Gradle Kotlin DSL, it is:
setProperty("archivesBaseName", "myExampleProject_lib")
Kotlin 插件支持 Gradle 构建缓存(需要 Gradle 4.3 及以上版本;低版本则禁用缓存)。
由于注解处理器运行的任意代码可能不一定会将任务输入转换为输出、可能访问与修改 Gradle 未跟踪的文件等,因此默认不缓存 kapt 注解处理任务。要启用 kapt 缓存,请将以下列几行添加到构建脚本中:
kapt { useBuildCache = true }
要禁用所有 Kotlin 任务的缓存,请将系统属性标志 kotlin.caching.enabled 设置为 false(运行构建带上参数 -Dkotlin.caching.enabled=false)。
kotlin.caching.enabled
false
-Dkotlin.caching.enabled=false
要指定附加的编译选项,请使用 Kotlin 编译任务的 kotlinOptions 属性。
kotlinOptions
当针对 JVM 时,对于生产代码这些任务称为 compileKotlin 而对于测试代码称为 compileTestKotlin。对于自定义源文件集(source set)这些任务称呼取决于 compile<Name>Kotlin 模式。
compileKotlin
compileTestKotlin
compile<Name>Kotlin
Android 项目中的任务名称包含构建变体 名称,并遵循 compile<BuildVariant>Kotlin 的模式,例如 compileDebugKotlin、 compileReleaseUnitTestKotlin。
compile<BuildVariant>Kotlin
compileDebugKotlin
compileReleaseUnitTestKotlin
当针对 JavaScript 时,这些任务分别称为 compileKotlin2Js 与 compileTestKotlin2Js,以及对于自定义源文件集称为 compile<Name>Kotlin2Js。
compileKotlin2Js
compileTestKotlin2Js
compile<Name>Kotlin2Js
要配置单个任务,请使用其名称。示例:
compileKotlin { kotlinOptions.suppressWarnings = true } compileKotlin { kotlinOptions { suppressWarnings = true } }
对于 Gradle Kotlin DSL,首先从项目的 tasks 中获取任务:
tasks
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile // …… val compileKotlin: KotlinCompile by tasks compileKotlin.kotlinOptions.suppressWarnings = true
相应地,为 JS 与 Common 目标使用类型 Kotlin2JsCompile 与 KotlinCompileCommon。
Kotlin2JsCompile
KotlinCompileCommon
也可以在项目中配置所有 Kotlin 编译任务:
tasks.withType(org.jetbrains.kotlin.gradle.tasks.KotlinCompile::class.java).all { kotlinOptions { …… } }
对于 Gradle 任务的完整选项列表如下:
allWarningsAsErrors
suppressWarnings
verbose
freeCompilerArgs
apiVersion
languageVersion
javaParameters
jdkHome
jvmTarget
noJdk
noReflect
noStdlib
friendModulesDisabled
main
metaInfo
moduleKind
outputFile
sourceMap
sourceMapEmbedSources
sourceMapPrefix
target
typedArrays
要生成 Kotlin 项目的文档,请使用 Dokka; 相关配置说明请参见 Dokka README 。Dokka 支持混合语言项目,并且可以生成多种格式的输出 ,包括标准 JavaDoc。
关于 OSGi 支持请参见 Kotlin OSGi 页。
使用 Gradle Kotlin DSL 时,请使用 plugins { …… } 块应用 Kotlin 插件。如果使用 apply { plugin(……) } 来应用的话,可能会遇到未解析的到由 Gradle Kotlin DSL 所生成扩展的引用问题。为了解决这个问题,可以注释掉出错的用法,运行 Gradle 任务 kotlinDslAccessorsSnapshot,然后解除该用法注释并重新运行构建或者重新将项目导入到 IDE 中。
plugins { …… }
apply { plugin(……) }
kotlinDslAccessorsSnapshot
以下示例显示了配置 Gradle 插件的不同可能性:
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8