Compiler options in the Kotlin Gradle plugin
Each release of Kotlin includes compilers for the supported targets: JVM, JavaScript, and native binaries for supported platforms.
These compilers are used by:
The IDE, when you click the Compile or Run button for your Kotlin project.
Gradle, when you call
gradle build
in a console or in the IDE.Maven, when you call
mvn compile
ormvn test-compile
in a console or in the IDE.
You can also run Kotlin compilers manually from the command line as described in the Working with command-line compiler tutorial.
How to define options
Kotlin compilers have a number of options for tailoring the compiling process.
The Gradle DSL allows comprehensive configuration of compiler options. It is available for Kotlin Multiplatform and JVM/Android projects.
With the Gradle DSL, you can configure compiler options within the build script at three levels:
Extension level, in the
kotlin {}
block for all targets and shared source sets.Target level, in the block for a specific target.
Compilation unit level, usually in a specific compilation task.
The settings at a higher level are used as a convention (default) for a lower level:
Compiler options set at the extension level are the default for target-level options, including shared source sets like
commonMain
,nativeMain
, andcommonTest
.Compiler options set at the target level are the default for options at the compilation unit (task) level, like
compileKotlinJvm
andcompileTestKotlinJvm
tasks.
In turn, configurations made at a lower level override related settings at a higher level:
Task-level compiler options override related configurations at the target or the extension level.
Target-level compiler options override related configurations at the extension level.
To find out which level of compiler arguments is applied to the compilation, use the DEBUG
level of Gradle logging. For JVM and JS/WASM tasks, search for the "Kotlin compiler args:"
string within the logs; for Native tasks, search for the "Arguments ="
string.
Extension level
You can configure common compiler options for all the targets and shared source sets in the compilerOptions {}
block at the top level:
Target level
You can configure compiler options for the JVM/Android target in the compilerOptions {}
block inside the target {}
block:
In Kotlin Multiplatform projects, you can configure compiler options inside the specific target. For example, jvm { compilerOptions {}}
. For more information, see Multiplatform Gradle DSL reference.
Compilation unit level
You can configure compiler options for a specific compilation unit or task in a compilerOptions {}
block inside the task configuration:
You can also access and configure compiler options at a compilation unit level via KotlinCompilation
:
If you want to configure a plugin of a target different from JVM/Android and Kotlin Multiplatform, use the compilerOptions {}
property of the corresponding Kotlin compilation task. The following examples show how to set this configuration up in both Kotlin and Groovy DSLs:
Target the JVM
As explained before, you can define compiler options for your JVM/Android projects at the extension, target, and compilation unit levels.
Default JVM compilation tasks are called compileKotlin
for production code and compileTestKotlin
for test code. The tasks for custom source sets are named according to their compile<Name>Kotlin
patterns.
You can see the list of Android compilation tasks by running the gradlew tasks --all
command in the terminal and searching for compile*Kotlin
task names in the Other tasks
group.
Some important details to be aware of:
The
android.kotlinOptions
andkotlin.compilerOptions
configuration blocks override each other. The last (lowest) block takes effect.kotlin.compilerOptions
configures every Kotlin compilation task in the project.You can override the configuration applied by
kotlin.compilerOptions
DSL using thetasks.named<KotlinJvmCompile>("compileKotlin") { }
(ortasks.withType<KotlinJvmCompile>().configureEach { }
) approach.
Target JavaScript
JavaScript compilation tasks are called compileKotlinJs
for production code, compileTestKotlinJs
for test code, and compile<Name>KotlinJs
for custom source sets.
To configure a single task, use its name:
Note that with the Gradle Kotlin DSL, you should get the task from the project's tasks
first.
Use the Kotlin2JsCompile
and KotlinCompileCommon
types for JS and common targets, respectively.
You can see the list of JavaScript compilation tasks by running the gradlew tasks --all
command in the terminal and searching for compile*KotlinJS
task names in the Other tasks
group.
All Kotlin compilation tasks
It is also possible to configure all the Kotlin compilation tasks in the project:
All compiler options
Here is a complete list of options for the Gradle compiler:
Common attributes
Name | Description | Possible values | Default value |
---|---|---|---|
| A property for configuring a list of opt-in compiler arguments |
|
|
| Enables the progressive compiler mode |
|
|
| Enables additional declaration, expression, and type compiler checks that emit warnings if true |
|
|
Attributes specific to JVM
Name | Description | Possible values | Default value |
---|---|---|---|
| Generate metadata for Java 1.8 reflection on method parameters | false | |
| Target version of the generated JVM bytecode | "1.8", "9", "10", ..., "22", "23". Also, see Types for compiler options | "1.8" |
| Don't automatically include the Java runtime into the classpath | false | |
|
|
|
|
Attributes common to JVM and JavaScript
Name | Description | Possible values | Default value |
---|---|---|---|
| Report an error if there are any warnings | false | |
| Don't generate warnings | false | |
| Enable verbose logging output. Works only when the Gradle debug log level enabled | false | |
| A list of additional compiler arguments. You can use experimental | [] | |
| Restrict the use of declarations to those from the specified version of bundled libraries | "1.8", "1.9", "2.0", "2.1", "2.2" (EXPERIMENTAL) | |
| Provide source compatibility with the specified version of Kotlin | "1.8", "1.9", "2.0", "2.1", "2.2" (EXPERIMENTAL) |
Example of additional arguments usage via freeCompilerArgs
Use the freeCompilerArgs
attribute to supply additional (including experimental) compiler arguments. You can add a single argument to this attribute or a list of arguments:
Example of setting languageVersion
To set a language version, use the following syntax:
Also, see Types for compiler options.
Attributes specific to JavaScript
Name | Description | Possible values | Default value |
---|---|---|---|
| Disable internal declaration export | false | |
| Define whether the | "call", "noCall". Also, see Types for compiler options | "call" |
| Generate .meta.js and .kjsm files with metadata. Use to create a library | true | |
| The kind of JS module generated by the compiler | "umd", "commonjs", "amd", "plain", "es". Also, see Types for compiler options | "umd" |
| Generate source map | true | |
| Embed source files into the source map | "never", "always", "inlining". Also, see Types for compiler options | |
| Add variable and function names that you declared in Kotlin code into the source map. For more information on the behavior, see our compiler reference. | "simple-names", "fully-qualified-names", "no". Also, see Types for compiler options | "simple-names" |
| Add the specified prefix to paths in the source map | ||
| Generate JS files for specific ECMA version | "v5" | "v5" |
| Translate primitive arrays to JS typed arrays | true |
Types for compiler options
Some of the compilerOptions
use the new types instead of the String
type:
Option | Type | Example |
---|---|---|
|
| |
|
| |
|
| |
|
| |
|
| |
|
|
What's next?
Learn more about: