Skip to content

Commit b7b0397

Browse files
dkrasnoffSpace Team
authored andcommitted
[Gradle] Made klib unpacked for native metadata compile task
^KT-63363 Fixed
1 parent 262697d commit b7b0397

File tree

13 files changed

+47
-41
lines changed

13 files changed

+47
-41
lines changed

libraries/tools/kotlin-gradle-plugin-integration-tests/src/test/kotlin/org/jetbrains/kotlin/gradle/CommonizerHierarchicalIT.kt

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -22,28 +22,28 @@ open class CommonizerHierarchicalIT : KGPBaseTest() {
2222
nativeProject("commonizeHierarchically", gradleVersion) {
2323
if (HostManager.hostIsMac) {
2424
build(":p1:compileIosMainKotlinMetadata") {
25-
assertFileInProjectExists("p1/build/classes/kotlin/metadata/iosMain/klib/p1_iosMain.klib")
25+
assertDirectoryInProjectExists("p1/build/classes/kotlin/metadata/iosMain/klib/p1_iosMain")
2626
assertNoDuplicateLibraryWarning()
2727
}
2828

2929
build(":p1:compileAppleMainKotlinMetadata") {
30-
assertFileInProjectExists("p1/build/classes/kotlin/metadata/appleMain/klib/p1_appleMain.klib")
30+
assertDirectoryInProjectExists("p1/build/classes/kotlin/metadata/appleMain/klib/p1_appleMain")
3131
assertNoDuplicateLibraryWarning()
3232
}
3333
}
3434

3535
build(":p1:compileLinuxMainKotlinMetadata") {
36-
assertFileInProjectExists("p1/build/classes/kotlin/metadata/linuxMain/klib/p1_linuxMain.klib")
36+
assertDirectoryInProjectExists("p1/build/classes/kotlin/metadata/linuxMain/klib/p1_linuxMain")
3737
assertNoDuplicateLibraryWarning()
3838
}
3939

4040
build(":p1:compileAppleAndLinuxMainKotlinMetadata") {
41-
assertFileInProjectExists("p1/build/classes/kotlin/metadata/appleAndLinuxMain/klib/p1_appleAndLinuxMain.klib")
41+
assertDirectoryInProjectExists("p1/build/classes/kotlin/metadata/appleAndLinuxMain/klib/p1_appleAndLinuxMain")
4242
assertNoDuplicateLibraryWarning()
4343
}
4444

4545
build(":p1:compileNativeMainKotlinMetadata") {
46-
assertFileInProjectExists("p1/build/classes/kotlin/metadata/nativeMain/klib/p1_nativeMain.klib")
46+
assertDirectoryInProjectExists("p1/build/classes/kotlin/metadata/nativeMain/klib/p1_nativeMain")
4747
assertNoDuplicateLibraryWarning()
4848
}
4949

libraries/tools/kotlin-gradle-plugin-integration-tests/src/test/kotlin/org/jetbrains/kotlin/gradle/ConfigurationCacheIT.kt

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -79,6 +79,19 @@ class ConfigurationCacheIT : AbstractConfigurationCacheIT() {
7979
}
8080
}
8181

82+
@MppGradlePluginTests
83+
@DisplayName("KT-63363: all metadata jar works well with configuration cache")
84+
@GradleTestVersions(
85+
minVersion = TestVersions.Gradle.G_7_4,
86+
additionalVersions = [TestVersions.Gradle.G_7_6],
87+
)
88+
@GradleTest
89+
fun testAllMetadataJarWithConfigurationCache(gradleVersion: GradleVersion) {
90+
project("new-mpp-lib-and-app/sample-lib", gradleVersion) {
91+
testConfigurationCacheOf(":allMetadataJar")
92+
}
93+
}
94+
8295
@NativeGradlePluginTests
8396
@DisplayName("works with commonizer")
8497
@GradleTestVersions(

libraries/tools/kotlin-gradle-plugin-integration-tests/src/test/kotlin/org/jetbrains/kotlin/gradle/HierarchicalMppIT.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -380,7 +380,7 @@ open class HierarchicalMppIT : KGPBaseTest() {
380380
) {
381381
build("assemble") {
382382
assertFileExists(projectPath.resolve("build/libs/test-project-jvm.jar"))
383-
assertFileExists(projectPath.resolve("build/classes/kotlin/metadata/nativeMain/klib/test-project_nativeMain.klib"))
383+
assertDirectoryExists(projectPath.resolve("build/classes/kotlin/metadata/nativeMain/klib/test-project_nativeMain"))
384384
}
385385
}
386386
}

libraries/tools/kotlin-gradle-plugin-integration-tests/src/test/kotlin/org/jetbrains/kotlin/gradle/KlibBasedMppIT.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -204,7 +204,7 @@ open class KlibBasedMppIT : BaseGradleIT() {
204204

205205
assertFileExists("build/classes/kotlin/metadata/commonMain/default/manifest")
206206
assertFileExists("build/classes/kotlin/metadata/jvmAndJsMain/default/manifest")
207-
assertFileExists("build/classes/kotlin/metadata/linuxMain/klib/${projectName}_linuxMain.klib")
207+
assertFileExists("build/classes/kotlin/metadata/linuxMain/klib/${projectName}_linuxMain")
208208

209209
// Check that the common and JVM+JS source sets don't receive the Kotlin/Native stdlib in the classpath:
210210
run {

libraries/tools/kotlin-gradle-plugin-integration-tests/src/test/kotlin/org/jetbrains/kotlin/gradle/mpp/MppSharedNativeCompileIT.kt

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -26,8 +26,8 @@ class MppSharedNativeCompileIT : KGPBaseTest() {
2626
fun `test - shared native klib - does not contain 'depends=' manifest property`(gradleVersion: GradleVersion) {
2727
project("kt-54995-compileSharedNative-with-okio", gradleVersion) {
2828
build("compileNativeMainKotlinMetadata") {
29-
val nativeMainKlib = projectPath.resolve("build/classes/kotlin/metadata/nativeMain/klib/test-project_nativeMain.klib")
30-
assertFileExists(nativeMainKlib)
29+
val nativeMainKlib = projectPath.resolve("build/classes/kotlin/metadata/nativeMain/klib/test-project_nativeMain")
30+
assertDirectoryExists(nativeMainKlib)
3131

3232
val libraryFile = org.jetbrains.kotlin.library.resolveSingleFileKlib(
3333
org.jetbrains.kotlin.konan.file.File(nativeMainKlib),

libraries/tools/kotlin-gradle-plugin/src/common/kotlin/org/jetbrains/kotlin/gradle/plugin/mpp/pm20/GradleKpmHostSpecificMetadataArtifact.kt

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,9 +8,7 @@ package org.jetbrains.kotlin.gradle.plugin.mpp.pm20
88
import org.gradle.api.artifacts.Dependency
99
import org.gradle.jvm.tasks.Jar
1010
import org.jetbrains.kotlin.gradle.plugin.mpp.pm20.util.disambiguateName
11-
import org.jetbrains.kotlin.gradle.targets.metadata.filesWithUnpackedArchives
1211
import org.jetbrains.kotlin.gradle.tasks.registerTask
13-
import org.jetbrains.kotlin.library.KLIB_FILE_EXTENSION
1412

1513
/**
1614
* Will register a 'hostSpecificMetadataJar' [Jar] task containing compilation outputs of host specific metadata.
@@ -29,7 +27,7 @@ val GradleKpmHostSpecificMetadataArtifact = GradleKpmConfigurationArtifactsSetup
2927
if (metadataCompilation is GradleKpmNativeFragmentMetadataCompilationData) {
3028
jar.from(project.files(project.provider {
3129
if (metadataFragment in fragment.withRefinesClosure && metadataFragment.isNativeHostSpecific())
32-
project.filesWithUnpackedArchives(metadataCompilation.output.allOutputs, setOf(KLIB_FILE_EXTENSION))
30+
metadataCompilation.output.allOutputs
3331
else emptyList<Any>()
3432
})) { spec -> spec.into(metadataFragment.name) }
3533
}

libraries/tools/kotlin-gradle-plugin/src/common/kotlin/org/jetbrains/kotlin/gradle/plugin/mpp/pm20/setupFragmentsMetadataForKpmModules.kt

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -18,14 +18,12 @@ import org.jetbrains.kotlin.gradle.plugin.mpp.pm20.util.ComputedCapability
1818
import org.jetbrains.kotlin.gradle.plugin.mpp.pm20.util.disambiguateName
1919
import org.jetbrains.kotlin.gradle.targets.metadata.KotlinMetadataTargetConfigurator
2020
import org.jetbrains.kotlin.gradle.targets.metadata.createGenerateProjectStructureMetadataTask
21-
import org.jetbrains.kotlin.gradle.targets.metadata.filesWithUnpackedArchives
2221
import org.jetbrains.kotlin.gradle.tasks.*
2322
import org.jetbrains.kotlin.gradle.tasks.withType
2423
import org.jetbrains.kotlin.gradle.utils.*
2524
import org.jetbrains.kotlin.gradle.utils.dashSeparatedName
2625
import org.jetbrains.kotlin.gradle.utils.filesProvider
2726
import org.jetbrains.kotlin.gradle.utils.lowerCamelCaseName
28-
import org.jetbrains.kotlin.library.KLIB_FILE_EXTENSION
2927
import org.jetbrains.kotlin.project.model.KpmFragment
3028
import java.util.concurrent.Callable
3129

@@ -162,7 +160,7 @@ private fun configureMetadataJarTask(
162160
val compilationData = registry.getForFragmentOrNull(fragment)
163161
.takeIf { !fragment.isNativeHostSpecific() }
164162
?: return@filesProvider emptyList<Any>()
165-
project.filesWithUnpackedArchives(compilationData.output.allOutputs, setOf(KLIB_FILE_EXTENSION))
163+
compilationData.output.allOutputs
166164
}
167165
jar.from(metadataOutput) { spec ->
168166
spec.into(fragment.fragmentName)

libraries/tools/kotlin-gradle-plugin/src/common/kotlin/org/jetbrains/kotlin/gradle/targets/metadata/KotlinMetadataTargetConfigurator.kt

Lines changed: 1 addition & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -320,8 +320,7 @@ class KotlinMetadataTargetConfigurator :
320320
configureMetadataDependenciesForCompilation(this@apply)
321321

322322
if (!isHostSpecific) {
323-
val metadataContent = project.filesWithUnpackedArchives(this@apply.output.allOutputs, setOf("klib"))
324-
allMetadataJar.configure { it.from(metadataContent) { spec -> spec.into(this@apply.defaultSourceSet.name) } }
323+
allMetadataJar.configure { it.from(this@apply.output.allOutputs) { spec -> spec.into(this@apply.defaultSourceSet.name) } }
325324
if (this is KotlinSharedNativeCompilation) {
326325
project.includeCommonizedCInteropMetadata(allMetadataJar, this)
327326
}
@@ -477,16 +476,6 @@ internal suspend fun getPublishedPlatformCompilations(project: Project): Map<Kot
477476
return result
478477
}
479478

480-
internal fun Project.filesWithUnpackedArchives(from: FileCollection, extensions: Set<String>): FileCollection =
481-
project.files(project.provider {
482-
from.mapNotNull {
483-
@Suppress("IMPLICIT_CAST_TO_ANY")
484-
if (it.extension in extensions) {
485-
if (it.exists()) project.zipTree(it) else null
486-
} else it
487-
}
488-
}).builtBy(from)
489-
490479
private val KotlinMetadataTarget.metadataCompilationsCreated: CompletableFuture<Unit> by extrasLazyProperty("metadataCompilationsCreated") {
491480
CompletableFuture()
492481
}

libraries/tools/kotlin-gradle-plugin/src/common/kotlin/org/jetbrains/kotlin/gradle/targets/native/KotlinNativeTarget.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -80,7 +80,7 @@ abstract class KotlinNativeTarget @Inject constructor(
8080
}
8181

8282
metadataCompilations.forEach { compilation ->
83-
metadataJar.from(project.filesWithUnpackedArchives(compilation.output.allOutputs, setOf("klib"))) { spec ->
83+
metadataJar.from(compilation.output.allOutputs) { spec ->
8484
spec.into(compilation.name)
8585
}
8686
metadataJar.dependsOn(compilation.output.classesDirs)

libraries/tools/kotlin-gradle-plugin/src/common/kotlin/org/jetbrains/kotlin/gradle/targets/native/KotlinNativeTargetConfigurator.kt

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,7 @@ import org.jetbrains.kotlin.gradle.plugin.mpp.*
3333
import org.jetbrains.kotlin.gradle.plugin.mpp.apple.XcodeVersionTask
3434
import org.jetbrains.kotlin.gradle.plugin.mpp.apple.registerEmbedAndSignAppleFrameworkTask
3535
import org.jetbrains.kotlin.gradle.plugin.mpp.apple.version
36+
import org.jetbrains.kotlin.gradle.plugin.mpp.pm20.GradleKpmMetadataCompilationData
3637
import org.jetbrains.kotlin.gradle.plugin.mpp.pm20.GradleKpmVariant
3738
import org.jetbrains.kotlin.gradle.plugin.mpp.pm20.util.copyAttributes
3839
import org.jetbrains.kotlin.gradle.targets.metadata.isKotlinGranularMetadataEnabled
@@ -45,8 +46,6 @@ import org.jetbrains.kotlin.gradle.tasks.*
4546
import org.jetbrains.kotlin.gradle.testing.internal.configureConventions
4647
import org.jetbrains.kotlin.gradle.testing.internal.kotlinTestRegistry
4748
import org.jetbrains.kotlin.gradle.testing.testTaskName
48-
import org.jetbrains.kotlin.gradle.utils.XcodeUtils
49-
import org.jetbrains.kotlin.gradle.utils.named
5049
import org.jetbrains.kotlin.gradle.utils.newInstance
5150
import org.jetbrains.kotlin.gradle.utils.valueSourceWithExecProviderCompat
5251
import org.jetbrains.kotlin.konan.target.HostManager
@@ -366,6 +365,7 @@ open class KotlinNativeTargetConfigurator<T : KotlinNativeTarget> : AbstractKotl
366365
): TaskProvider<KotlinNativeCompile> {
367366
val project = compilationInfo.project
368367
val ext = project.topLevelExtension
368+
val isMetadataCompilation = checkCompilationIsMetadataCompilation(compilationInfo)
369369
val compileTaskProvider = project.registerTask<KotlinNativeCompile>(
370370
compilationInfo.compileKotlinTaskName,
371371
listOf(
@@ -399,6 +399,8 @@ open class KotlinNativeTargetConfigurator<T : KotlinNativeTarget> : AbstractKotl
399399
)
400400
.finalizeValueOnRead()
401401

402+
// for metadata tasks we should provide unpacked klib
403+
it.produceUnpackedKlib.set(isMetadataCompilation)
402404
}
403405

404406
compilationInfo.classesDirs.from(compileTaskProvider.map { it.outputFile })
@@ -429,6 +431,13 @@ open class KotlinNativeTargetConfigurator<T : KotlinNativeTarget> : AbstractKotl
429431
return compileTaskProvider
430432
}
431433

434+
private fun checkCompilationIsMetadataCompilation(compilationInfo: KotlinCompilationInfo): Boolean {
435+
return when (compilationInfo) {
436+
is KPM -> compilationInfo.compilationData is GradleKpmMetadataCompilationData<*>
437+
is KotlinCompilationInfo.TCS -> compilationInfo.compilation is KotlinMetadataCompilation<*>
438+
}
439+
}
440+
432441
private fun Project.klibOutputDirectory(
433442
compilation: KotlinCompilationInfo,
434443
): DirectoryProperty {

0 commit comments

Comments
 (0)