[K2 JS] Do not load transitive dependencies for building K2/JS klibs
^KT-57262 Fixed
This commit is contained in:
committed by
Space Team
parent
62fb3df7f0
commit
e3402fcc87
@@ -78,7 +78,7 @@ fun compileModuleToAnalyzedFir(
|
||||
// TODO: !!! dependencies module data?
|
||||
}
|
||||
|
||||
val resolvedLibraries = moduleStructure.fullResolvedLibraries
|
||||
val resolvedLibraries = moduleStructure.allDependencies
|
||||
|
||||
val sessionsWithSources = prepareJsSessions(
|
||||
ktFiles, moduleStructure.compilerConfiguration, escapedMainModuleName,
|
||||
@@ -106,11 +106,11 @@ fun transformFirToIr(
|
||||
var builtInsModule: KotlinBuiltIns? = null
|
||||
val dependencies = mutableListOf<ModuleDescriptorImpl>()
|
||||
|
||||
val librariesDescriptors = moduleStructure.fullResolvedLibraries.map { resolvedLibrary ->
|
||||
val librariesDescriptors = moduleStructure.allDependencies.map { resolvedLibrary ->
|
||||
val storageManager = LockBasedStorageManager("ModulesStructure")
|
||||
|
||||
val moduleDescriptor = JsFactories.DefaultDeserializedDescriptorFactory.createDescriptorOptionalBuiltIns(
|
||||
resolvedLibrary.library,
|
||||
resolvedLibrary,
|
||||
moduleStructure.compilerConfiguration.languageVersionSettings,
|
||||
storageManager,
|
||||
builtInsModule,
|
||||
@@ -120,7 +120,7 @@ fun transformFirToIr(
|
||||
dependencies += moduleDescriptor
|
||||
moduleDescriptor.setDependencies(ArrayList(dependencies))
|
||||
|
||||
val isBuiltIns = resolvedLibrary.library.unresolvedDependencies.isEmpty()
|
||||
val isBuiltIns = resolvedLibrary.unresolvedDependencies.isEmpty()
|
||||
if (isBuiltIns) builtInsModule = moduleDescriptor.builtIns
|
||||
|
||||
moduleDescriptor
|
||||
@@ -170,7 +170,7 @@ fun serializeFirKlib(
|
||||
moduleStructure.compilerConfiguration.get(IrMessageLogger.IR_MESSAGE_LOGGER) ?: IrMessageLogger.None,
|
||||
sourceFiles,
|
||||
klibPath = outputKlibPath,
|
||||
moduleStructure.fullResolvedLibraries.map { it.library },
|
||||
moduleStructure.allDependencies,
|
||||
irResult.irModuleFragment,
|
||||
expectDescriptorToSymbol = mutableMapOf(),
|
||||
cleanFiles = icData,
|
||||
|
||||
@@ -20,6 +20,7 @@ import org.jetbrains.kotlin.fir.session.*
|
||||
import org.jetbrains.kotlin.fir.session.environment.AbstractProjectEnvironment
|
||||
import org.jetbrains.kotlin.fir.session.environment.AbstractProjectFileSearchScope
|
||||
import org.jetbrains.kotlin.js.resolve.JsPlatformAnalyzerServices
|
||||
import org.jetbrains.kotlin.library.KotlinLibrary
|
||||
import org.jetbrains.kotlin.library.metadata.resolver.KotlinResolvedLibrary
|
||||
import org.jetbrains.kotlin.load.kotlin.PackageAndMetadataPartProvider
|
||||
import org.jetbrains.kotlin.name.Name
|
||||
@@ -110,7 +111,7 @@ fun <F> prepareJsSessions(
|
||||
files: List<F>,
|
||||
configuration: CompilerConfiguration,
|
||||
rootModuleName: Name,
|
||||
resolvedLibraries: List<KotlinResolvedLibrary>,
|
||||
resolvedLibraries: List<KotlinLibrary>,
|
||||
libraryList: DependencyListForCliModule,
|
||||
extensionRegistrars: List<FirExtensionRegistrar>,
|
||||
isCommonSource: (F) -> Boolean,
|
||||
|
||||
+1
-1
@@ -66,7 +66,7 @@ object FirCommonSessionFactory : FirAbstractSessionFactory() {
|
||||
session,
|
||||
moduleDataProvider,
|
||||
kotlinScopeProvider,
|
||||
resolvedKLibs
|
||||
resolvedKLibs.map { it.library }
|
||||
)
|
||||
},
|
||||
FirBuiltinSymbolProvider(session, builtinsModuleData, kotlinScopeProvider),
|
||||
|
||||
@@ -18,6 +18,7 @@ import org.jetbrains.kotlin.fir.scopes.FirKotlinScopeProvider
|
||||
import org.jetbrains.kotlin.fir.scopes.FirPlatformClassMapper
|
||||
import org.jetbrains.kotlin.fir.scopes.impl.FirEnumEntriesSupport
|
||||
import org.jetbrains.kotlin.incremental.components.LookupTracker
|
||||
import org.jetbrains.kotlin.library.KotlinLibrary
|
||||
import org.jetbrains.kotlin.library.metadata.resolver.KotlinResolvedLibrary
|
||||
import org.jetbrains.kotlin.name.Name
|
||||
|
||||
@@ -58,7 +59,7 @@ object FirJsSessionFactory : FirAbstractSessionFactory() {
|
||||
|
||||
fun createLibrarySession(
|
||||
mainModuleName: Name,
|
||||
resolvedLibraries: List<KotlinResolvedLibrary>,
|
||||
resolvedLibraries: List<KotlinLibrary>,
|
||||
sessionProvider: FirProjectSessionProvider,
|
||||
moduleDataProvider: ModuleDataProvider,
|
||||
languageVersionSettings: LanguageVersionSettings = LanguageVersionSettingsImpl.DEFAULT,
|
||||
|
||||
+1
-1
@@ -46,7 +46,7 @@ object FirNativeSessionFactory : FirAbstractSessionFactory() {
|
||||
bindSession(session)
|
||||
}
|
||||
listOf(
|
||||
KlibBasedSymbolProvider(session, moduleDataProvider, kotlinScopeProvider, resolvedLibraries),
|
||||
KlibBasedSymbolProvider(session, moduleDataProvider, kotlinScopeProvider, resolvedLibraries.map { it.library }),
|
||||
NativeForwardDeclarationsSymbolProvider(session, forwardDeclarationsModuleData, kotlinScopeProvider, resolvedLibraries),
|
||||
FirBuiltinSymbolProvider(session, builtinsModuleData, kotlinScopeProvider),
|
||||
FirExtensionSyntheticFunctionInterfaceProvider(session, builtinsModuleData, kotlinScopeProvider),
|
||||
|
||||
+16
-18
@@ -15,10 +15,8 @@ import org.jetbrains.kotlin.fir.isNewPlaceForBodyGeneration
|
||||
import org.jetbrains.kotlin.fir.languageVersionSettings
|
||||
import org.jetbrains.kotlin.fir.scopes.FirKotlinScopeProvider
|
||||
import org.jetbrains.kotlin.fir.symbols.SymbolInternals
|
||||
import org.jetbrains.kotlin.library.metadata.KlibDeserializedContainerSource
|
||||
import org.jetbrains.kotlin.library.metadata.KlibMetadataClassDataFinder
|
||||
import org.jetbrains.kotlin.library.metadata.KlibMetadataProtoBuf
|
||||
import org.jetbrains.kotlin.library.metadata.KlibMetadataSerializerProtocol
|
||||
import org.jetbrains.kotlin.library.KotlinLibrary
|
||||
import org.jetbrains.kotlin.library.metadata.*
|
||||
import org.jetbrains.kotlin.library.metadata.resolver.KotlinResolvedLibrary
|
||||
import org.jetbrains.kotlin.metadata.ProtoBuf
|
||||
import org.jetbrains.kotlin.metadata.deserialization.NameResolver
|
||||
@@ -34,17 +32,17 @@ class KlibBasedSymbolProvider(
|
||||
session: FirSession,
|
||||
moduleDataProvider: ModuleDataProvider,
|
||||
kotlinScopeProvider: FirKotlinScopeProvider,
|
||||
private val resolvedLibraries: Collection<KotlinResolvedLibrary>,
|
||||
private val resolvedLibraries: Collection<KotlinLibrary>,
|
||||
defaultDeserializationOrigin: FirDeclarationOrigin = FirDeclarationOrigin.Library
|
||||
) : AbstractFirDeserializedSymbolProvider(
|
||||
session, moduleDataProvider, kotlinScopeProvider, defaultDeserializationOrigin, KlibMetadataSerializerProtocol
|
||||
) {
|
||||
private val moduleHeaders by lazy {
|
||||
resolvedLibraries.associate { it to it.loadModuleHeader(it.library) }
|
||||
resolvedLibraries.associate { it to parseModuleHeader(it.moduleHeaderData) }
|
||||
}
|
||||
|
||||
private val fragmentNamesInLibraries: Map<String, List<KotlinResolvedLibrary>> by lazy {
|
||||
buildMap<String, SmartList<KotlinResolvedLibrary>> {
|
||||
private val fragmentNamesInLibraries: Map<String, List<KotlinLibrary>> by lazy {
|
||||
buildMap<String, SmartList<KotlinLibrary>> {
|
||||
for ((library, header) in moduleHeaders) {
|
||||
for (fragmentName in header.packageFragmentNameList) {
|
||||
getOrPut(fragmentName) { SmartList() }
|
||||
@@ -57,15 +55,15 @@ class KlibBasedSymbolProvider(
|
||||
private val annotationDeserializer = KlibBasedAnnotationDeserializer(session)
|
||||
private val constDeserializer = FirConstDeserializer(session, KlibMetadataSerializerProtocol)
|
||||
private val deserializationConfiguration = CompilerDeserializationConfiguration(session.languageVersionSettings)
|
||||
private val cachedFragments = mutableMapOf<KotlinResolvedLibrary, MutableMap<Pair<String, String>, ProtoBuf.PackageFragment>>()
|
||||
private val cachedFragments = mutableMapOf<KotlinLibrary, MutableMap<Pair<String, String>, ProtoBuf.PackageFragment>>()
|
||||
|
||||
private fun getPackageFragment(
|
||||
resolvedLibrary: KotlinResolvedLibrary, packageStringName: String, packageMetadataPart: String
|
||||
resolvedLibrary: KotlinLibrary, packageStringName: String, packageMetadataPart: String
|
||||
): ProtoBuf.PackageFragment {
|
||||
return cachedFragments.getOrPut(resolvedLibrary) {
|
||||
mutableMapOf()
|
||||
}.getOrPut(packageStringName to packageMetadataPart) {
|
||||
resolvedLibrary.loadPackageFragment(resolvedLibrary.library, packageStringName, packageMetadataPart)
|
||||
parsePackageFragment(resolvedLibrary.packageMetadata(packageStringName, packageMetadataPart))
|
||||
}
|
||||
}
|
||||
|
||||
@@ -75,10 +73,10 @@ class KlibBasedSymbolProvider(
|
||||
val librariesWithFragment = fragmentNamesInLibraries[packageStringName] ?: return emptyList()
|
||||
|
||||
return librariesWithFragment.flatMap { resolvedLibrary ->
|
||||
resolvedLibrary.library.packageMetadataParts(packageStringName).mapNotNull {
|
||||
resolvedLibrary.packageMetadataParts(packageStringName).mapNotNull {
|
||||
val fragment = getPackageFragment(resolvedLibrary, packageStringName, it)
|
||||
|
||||
val libraryPath = Paths.get(resolvedLibrary.library.libraryFile.path)
|
||||
val libraryPath = Paths.get(resolvedLibrary.libraryFile.path)
|
||||
val moduleData = moduleDataProvider.getModuleData(libraryPath) ?: return@mapNotNull null
|
||||
val packageProto = fragment.`package`
|
||||
|
||||
@@ -117,7 +115,7 @@ class KlibBasedSymbolProvider(
|
||||
val finder = KlibMetadataClassDataFinder(fragment, nameResolver)
|
||||
val classProto = finder.findClassData(classId)?.classProto ?: return@forEachFragmentInPackage
|
||||
|
||||
val libraryPath = Paths.get(resolvedLibrary.library.libraryFile.path)
|
||||
val libraryPath = Paths.get(resolvedLibrary.libraryFile.path)
|
||||
val moduleData = moduleDataProvider.getModuleData(libraryPath) ?: return null
|
||||
|
||||
return ClassMetadataFindResult.NoMetadata { symbol ->
|
||||
@@ -150,14 +148,14 @@ class KlibBasedSymbolProvider(
|
||||
|
||||
private inline fun forEachFragmentInPackage(
|
||||
packageFqName: FqName,
|
||||
f: (KotlinResolvedLibrary, ProtoBuf.PackageFragment, NameResolver) -> Unit
|
||||
f: (KotlinLibrary, ProtoBuf.PackageFragment, NameResolver) -> Unit
|
||||
) {
|
||||
val packageStringName = packageFqName.asString()
|
||||
|
||||
val librariesWithFragment = fragmentNamesInLibraries[packageStringName] ?: return
|
||||
|
||||
for (resolvedLibrary in librariesWithFragment) {
|
||||
for (packageMetadataPart in resolvedLibrary.library.packageMetadataParts(packageStringName)) {
|
||||
for (packageMetadataPart in resolvedLibrary.packageMetadataParts(packageStringName)) {
|
||||
|
||||
val fragment = getPackageFragment(resolvedLibrary, packageStringName, packageMetadataPart)
|
||||
|
||||
@@ -172,10 +170,10 @@ class KlibBasedSymbolProvider(
|
||||
}
|
||||
|
||||
private fun createDeserializedContainerSource(
|
||||
resolvedLibrary: KotlinResolvedLibrary,
|
||||
resolvedLibrary: KotlinLibrary,
|
||||
packageFqName: FqName
|
||||
) = KlibDeserializedContainerSource(
|
||||
resolvedLibrary.library,
|
||||
resolvedLibrary,
|
||||
moduleHeaders[resolvedLibrary]!!,
|
||||
deserializationConfiguration,
|
||||
packageFqName
|
||||
|
||||
@@ -477,10 +477,6 @@ class ModulesStructure(
|
||||
compilerConfiguration.get(JSConfigurationKeys.ZIP_FILE_SYSTEM_ACCESSOR)
|
||||
)
|
||||
|
||||
val fullResolvedLibraries by lazy {
|
||||
allDependenciesResolution.resolveWithDependencies().getFullResolvedList()
|
||||
}
|
||||
|
||||
val allDependencies: List<KotlinLibrary>
|
||||
get() = allDependenciesResolution.libraries
|
||||
|
||||
|
||||
+1
-1
@@ -42,7 +42,7 @@ object TestFirJsSessionFactory {
|
||||
|
||||
return FirJsSessionFactory.createLibrarySession(
|
||||
mainModuleName,
|
||||
resolvedLibraries,
|
||||
resolvedLibraries.map { it.library },
|
||||
sessionProvider,
|
||||
moduleDataProvider,
|
||||
languageVersionSettings,
|
||||
|
||||
@@ -7138,6 +7138,12 @@ public class BoxJsTestGenerated extends AbstractBoxJsTest {
|
||||
runTest("js/js.translator/testData/box/multiModule/symbolRedeclaration.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("transitiveDependency.kt")
|
||||
public void testTransitiveDependency() throws Exception {
|
||||
runTest("js/js.translator/testData/box/multiModule/transitiveDependency.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("useElementsFromDefaultPackageInAnotherModule.kt")
|
||||
public void testUseElementsFromDefaultPackageInAnotherModule() throws Exception {
|
||||
|
||||
+6
@@ -7820,6 +7820,12 @@ public class FirJsBoxTestGenerated extends AbstractFirJsBoxTest {
|
||||
runTest("js/js.translator/testData/box/multiModule/symbolRedeclaration.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("transitiveDependency.kt")
|
||||
public void testTransitiveDependency() throws Exception {
|
||||
runTest("js/js.translator/testData/box/multiModule/transitiveDependency.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("useElementsFromDefaultPackageInAnotherModule.kt")
|
||||
public void testUseElementsFromDefaultPackageInAnotherModule() throws Exception {
|
||||
|
||||
+6
@@ -7926,6 +7926,12 @@ public class IrBoxJsES6TestGenerated extends AbstractIrBoxJsES6Test {
|
||||
runTest("js/js.translator/testData/box/multiModule/symbolRedeclaration.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("transitiveDependency.kt")
|
||||
public void testTransitiveDependency() throws Exception {
|
||||
runTest("js/js.translator/testData/box/multiModule/transitiveDependency.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("useElementsFromDefaultPackageInAnotherModule.kt")
|
||||
public void testUseElementsFromDefaultPackageInAnotherModule() throws Exception {
|
||||
|
||||
+6
@@ -7820,6 +7820,12 @@ public class IrBoxJsTestGenerated extends AbstractIrBoxJsTest {
|
||||
runTest("js/js.translator/testData/box/multiModule/symbolRedeclaration.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("transitiveDependency.kt")
|
||||
public void testTransitiveDependency() throws Exception {
|
||||
runTest("js/js.translator/testData/box/multiModule/transitiveDependency.kt");
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestMetadata("useElementsFromDefaultPackageInAnotherModule.kt")
|
||||
public void testUseElementsFromDefaultPackageInAnotherModule() throws Exception {
|
||||
|
||||
@@ -0,0 +1,15 @@
|
||||
// KJS_WITH_FULL_RUNTIME
|
||||
// MODULE: lib1
|
||||
// FILE: lib1.kt
|
||||
|
||||
fun module1() = "K"
|
||||
|
||||
// MODULE: lib2(lib1)
|
||||
// FILE: lib2.kt
|
||||
|
||||
fun module2() = "O" + module1()
|
||||
|
||||
// MODULE: main(lib2)
|
||||
// FILE: main.kt
|
||||
|
||||
fun box() = module2()
|
||||
+27
-2
@@ -385,9 +385,9 @@ class Kotlin2JsIrGradlePluginIT : AbstractKotlin2JsGradlePluginIT(true) {
|
||||
}
|
||||
}
|
||||
|
||||
@DisplayName("JS IR implementation dependency")
|
||||
@DisplayName("K1/JS IR implementation dependency")
|
||||
@GradleTest
|
||||
fun testJsIrImplementationDependency(gradleVersion: GradleVersion) {
|
||||
fun testK1JsIrImplementationDependency(gradleVersion: GradleVersion) {
|
||||
project("kotlin-js-browser-project", gradleVersion) {
|
||||
buildGradleKts.modify(::transformBuildScriptWithPluginsDsl)
|
||||
|
||||
@@ -401,6 +401,31 @@ class Kotlin2JsIrGradlePluginIT : AbstractKotlin2JsGradlePluginIT(true) {
|
||||
}
|
||||
}
|
||||
|
||||
@DisplayName("K2/JS IR implementation dependency")
|
||||
@GradleTest
|
||||
fun testK2JsIrImplementationDependency(gradleVersion: GradleVersion) {
|
||||
project("kotlin-js-browser-project", gradleVersion) {
|
||||
buildGradleKts.modify(::transformBuildScriptWithPluginsDsl)
|
||||
buildGradleKts.append(
|
||||
"""
|
||||
rootProject.subprojects.forEach {
|
||||
it.tasks.withType<org.jetbrains.kotlin.gradle.tasks.Kotlin2JsCompile> {
|
||||
kotlinOptions.languageVersion = "2.0"
|
||||
}
|
||||
}
|
||||
""".trimIndent()
|
||||
)
|
||||
|
||||
build(":app:compileProductionExecutableKotlinJs")
|
||||
|
||||
projectPath.resolve("app/src/main/kotlin/App.kt").modify {
|
||||
it.replace("sheldon()", "best()")
|
||||
}
|
||||
|
||||
buildAndFail(":app:compileProductionExecutableKotlinJs")
|
||||
}
|
||||
}
|
||||
|
||||
@DisplayName("JS IR compiled against automatically added dom-api-compat")
|
||||
@GradleTest
|
||||
fun testJsIrCompiledAgainstAutomaticallyAddedDomApiCompat(gradleVersion: GradleVersion) {
|
||||
|
||||
Reference in New Issue
Block a user