From c645f52545d21562b27e2b76b1e1d6407453fe13 Mon Sep 17 00:00:00 2001 From: Leonid Startsev Date: Fri, 20 Dec 2024 17:25:50 +0100 Subject: [PATCH] Restructure source-sets-conventions.gradle.kts so it applies overridenLanugageVersion to all source sets using the new compilerOptions DSL. (#2891) Previously, only leaf source sets were affected because the language version was applied to the KotlinCompilationTask configuration. --- .../kotlin/source-sets-conventions.gradle.kts | 27 +++++++++++-------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/buildSrc/src/main/kotlin/source-sets-conventions.gradle.kts b/buildSrc/src/main/kotlin/source-sets-conventions.gradle.kts index 008628c3b9..311df3fb9f 100644 --- a/buildSrc/src/main/kotlin/source-sets-conventions.gradle.kts +++ b/buildSrc/src/main/kotlin/source-sets-conventions.gradle.kts @@ -64,14 +64,24 @@ kotlin { sourceSets.all { kotlin.srcDirs("$name/src") resources.srcDirs("$name/resources") - languageSettings { - progressiveMode = true + } - optIn("kotlin.ExperimentalMultiplatform") - optIn("kotlin.ExperimentalSubclassOptIn") - optIn("kotlinx.serialization.InternalSerializationApi") - optIn("kotlinx.serialization.SealedSerializationApi") + compilerOptions { + // These configuration replaces 'languageSettings' config on line 67 + progressiveMode.set(true) + optIn.addAll( + listOf( + "kotlin.ExperimentalMultiplatform", + "kotlin.ExperimentalSubclassOptIn", + "kotlinx.serialization.InternalSerializationApi", + "kotlinx.serialization.SealedSerializationApi", + ) + ) + if (overriddenLanguageVersion != null) { + languageVersion = KotlinVersion.fromVersion(overriddenLanguageVersion!!) + freeCompilerArgs.add("-Xsuppress-version-warnings") } + freeCompilerArgs.add("-Xexpect-actual-classes") } sourceSets { @@ -126,10 +136,5 @@ tasks.withType(KotlinCompilationTask::class).configureEach { if (isMainTaskName) { allWarningsAsErrors = true } - if (overriddenLanguageVersion != null) { - languageVersion = KotlinVersion.fromVersion(overriddenLanguageVersion!!) - freeCompilerArgs.add("-Xsuppress-version-warnings") - } - freeCompilerArgs.add("-Xexpect-actual-classes") } }