From dea38912fc788f9dddc4a22f19a995c0b25f7933 Mon Sep 17 00:00:00 2001 From: AntsyLich <59261191+AntsyLich@users.noreply.github.com> Date: Fri, 30 Aug 2024 13:55:11 +0600 Subject: [PATCH] Use feature flags in compose compiler plugin And slight cleanup (cherry picked from commit 8f9a325895bb7b94c2ec92dd969094fc30b3b5e2) --- .../mihon/buildlogic/ProjectExtensions.kt | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/buildSrc/src/main/kotlin/mihon/buildlogic/ProjectExtensions.kt b/buildSrc/src/main/kotlin/mihon/buildlogic/ProjectExtensions.kt index ae18dd637383..86d16d33b569 100644 --- a/buildSrc/src/main/kotlin/mihon/buildlogic/ProjectExtensions.kt +++ b/buildSrc/src/main/kotlin/mihon/buildlogic/ProjectExtensions.kt @@ -14,6 +14,7 @@ import org.gradle.kotlin.dsl.provideDelegate import org.gradle.kotlin.dsl.the import org.gradle.kotlin.dsl.withType import org.jetbrains.kotlin.compose.compiler.gradle.ComposeCompilerGradlePluginExtension +import org.jetbrains.kotlin.compose.compiler.gradle.ComposeFeatureFlag import org.jetbrains.kotlin.gradle.tasks.KotlinCompile import java.io.File @@ -75,25 +76,20 @@ internal fun Project.configureCompose(commonExtension: CommonExtension<*, *, *, } extensions.configure { - // Enable strong skipping mode - enableStrongSkippingMode.set(true) - - // Enable experimental compiler opts - // https://developer.android.com/jetpack/androidx/releases/compose-compiler#1.5.9 - enableNonSkippingGroupOptimization.set(true) + featureFlags.set(setOf(ComposeFeatureFlag.OptimizeNonSkippingGroups)) val enableMetrics = project.providers.gradleProperty("enableComposeCompilerMetrics").orNull.toBoolean() val enableReports = project.providers.gradleProperty("enableComposeCompilerReports").orNull.toBoolean() - val rootProjectDir = rootProject.layout.buildDirectory.asFile.get() + val rootBuildDir = rootProject.layout.buildDirectory.asFile.get() val relativePath = projectDir.relativeTo(rootDir) + if (enableMetrics) { - val buildDirPath = rootProjectDir.resolve("compose-metrics").resolve(relativePath) - metricsDestination.set(buildDirPath) + rootBuildDir.resolve("compose-metrics").resolve(relativePath).let(metricsDestination::set) } + if (enableReports) { - val buildDirPath = rootProjectDir.resolve("compose-reports").resolve(relativePath) - reportsDestination.set(buildDirPath) + rootBuildDir.resolve("compose-reports").resolve(relativePath).let(reportsDestination::set) } }