The Compose compiler is supplemented by a Gradle plugin, which simplifies setup and offers easier access to compiler options. When applied with the Android Gradle plugin (AGP), this Compose compiler plugin will override the coordinates of the Compose compiler supplied automatically by AGP.
The Compose compiler has been merged into the Kotlin repository since Kotlin 2.0.0. This helps smooth the migration of your projects to Kotlin 2.0.0 and later, as the Compose compiler ships simultaneously with Kotlin and will always be compatible with Kotlin of the same version.
To use the new Compose compiler plugin in your project, apply it for each module that uses Compose. Read on for details on how to migrate a Jetpack Compose project. For a Compose Multiplatform project, refer to the multiplatform migration guide.
When migrating to Kotlin 2.0.0 or newer from 1.9, you should adjust your project configuration depending on the way you deal with the Compose compiler. We recommend using the Kotlin Gradle plugin and the Compose compiler Gradle plugin to automate configuration management.
For Android modules:
- Add the Compose compiler Gradle plugin to the Gradle version catalog:
[versions]
# ...
kotlin = "%kotlinVersion%"
[plugins]
# ...
org-jetbrains-kotlin-android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin" }
compose-compiler = { id = "org.jetbrains.kotlin.plugin.compose", version.ref = "kotlin" }
- Add the Gradle plugin to the root
build.gradle.kts
file:
plugins {
// ...
alias(libs.plugins.compose.compiler) apply false
}
- Apply the plugin to every module that uses Jetpack Compose:
plugins {
// ...
alias(libs.plugins.compose.compiler)
}
-
If you are using compiler options for the Jetpack Compose compiler, set them in the
composeCompiler {}
block. See the list of compiler options for reference. -
If you reference Compose compiler artifacts directly, you can remove these references and let the Gradle plugins take care of things.
If you are not using Gradle plugins to manage the Compose compiler, update any direct references to old Maven artifacts in your project:
- Change
androidx.compose.compiler:compiler
toorg.jetbrains.kotlin:kotlin-compose-compiler-plugin-embeddable
- Change
androidx.compose.compiler:compiler-hosted
toorg.jetbrains.kotlin:kotlin-compose-compiler-plugin
- See Google's announcement about the Compose compiler moving to the Kotlin repository.
- If you are using Jetpack Compose to build an Android app, check out our guide on how to make it multiplatform.