Don't add Enum.entries to scope if it can't be called
^KT-53929 Fixed
This commit is contained in:
+2
-1
@@ -63,7 +63,8 @@ class DeserializerForClassfileDecompiler(
|
||||
LookupTracker.DO_NOTHING, JavaFlexibleTypeDeserializer, emptyList(), notFoundClasses,
|
||||
ContractDeserializerImpl(configuration, storageManager),
|
||||
extensionRegistryLite = JvmProtoBufUtil.EXTENSION_REGISTRY,
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList())
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList()),
|
||||
enumEntriesDeserializationSupport = enumEntriesDeserializationSupport,
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
+5
@@ -11,7 +11,9 @@ import org.jetbrains.kotlin.descriptors.impl.MutablePackageFragmentDescriptor
|
||||
import org.jetbrains.kotlin.name.ClassId
|
||||
import org.jetbrains.kotlin.name.FqName
|
||||
import org.jetbrains.kotlin.name.Name
|
||||
import org.jetbrains.kotlin.resolve.jvm.EnumEntriesDeserializationSupportImpl
|
||||
import org.jetbrains.kotlin.serialization.deserialization.DeserializationComponents
|
||||
import org.jetbrains.kotlin.serialization.deserialization.EnumEntriesDeserializationSupport
|
||||
import org.jetbrains.kotlin.serialization.deserialization.LocalClassifierTypeSettings
|
||||
import org.jetbrains.kotlin.storage.LockBasedStorageManager
|
||||
import org.jetbrains.kotlin.storage.StorageManager
|
||||
@@ -43,6 +45,9 @@ abstract class DeserializerForDecompilerBase(val directoryPackageFqName: FqName)
|
||||
}
|
||||
}
|
||||
|
||||
protected val enumEntriesDeserializationSupport: EnumEntriesDeserializationSupport =
|
||||
EnumEntriesDeserializationSupportImpl(moduleDescriptor.platform)
|
||||
|
||||
override fun resolveTopLevelClass(classId: ClassId) = deserializationComponents.deserializeClass(classId)
|
||||
|
||||
protected fun createDummyPackageFragment(fqName: FqName): MutablePackageFragmentDescriptor =
|
||||
|
||||
+2
-1
@@ -40,7 +40,8 @@ class KotlinMetadataDeserializerForDecompiler(
|
||||
LookupTracker.DO_NOTHING, flexibleTypeDeserializer, emptyList(), notFoundClasses,
|
||||
ContractDeserializer.DEFAULT,
|
||||
extensionRegistryLite = serializerProtocol.extensionRegistry,
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList())
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList()),
|
||||
enumEntriesDeserializationSupport = enumEntriesDeserializationSupport,
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
+16
@@ -0,0 +1,16 @@
|
||||
/*
|
||||
* Copyright 2010-2023 JetBrains s.r.o. and Kotlin Programming Language contributors.
|
||||
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
|
||||
*/
|
||||
|
||||
package org.jetbrains.kotlin.resolve.jvm
|
||||
|
||||
import org.jetbrains.kotlin.platform.TargetPlatform
|
||||
import org.jetbrains.kotlin.platform.jvm.isJvm
|
||||
import org.jetbrains.kotlin.serialization.deserialization.EnumEntriesDeserializationSupport
|
||||
|
||||
class EnumEntriesDeserializationSupportImpl(
|
||||
private val platform: TargetPlatform?,
|
||||
) : EnumEntriesDeserializationSupport {
|
||||
override fun canSynthesizeEnumEntries(): Boolean = platform.isJvm()
|
||||
}
|
||||
+3
-1
@@ -14,6 +14,7 @@ import org.jetbrains.kotlin.load.kotlin.PackagePartProvider
|
||||
import org.jetbrains.kotlin.name.ClassId
|
||||
import org.jetbrains.kotlin.name.FqName
|
||||
import org.jetbrains.kotlin.name.Name
|
||||
import org.jetbrains.kotlin.resolve.jvm.EnumEntriesDeserializationSupportImpl
|
||||
import org.jetbrains.kotlin.resolve.jvm.JvmCompilerDeserializationConfiguration
|
||||
import org.jetbrains.kotlin.resolve.sam.SamConversionResolver
|
||||
import org.jetbrains.kotlin.resolve.scopes.DescriptorKindFilter
|
||||
@@ -61,7 +62,8 @@ class OptionalAnnotationPackageFragmentProvider(
|
||||
notFoundClasses,
|
||||
ContractDeserializer.DEFAULT,
|
||||
extensionRegistryLite = serializerProtocol.extensionRegistry,
|
||||
samConversionResolver = SamConversionResolver.Empty
|
||||
samConversionResolver = SamConversionResolver.Empty,
|
||||
enumEntriesDeserializationSupport = EnumEntriesDeserializationSupportImpl(module.platform),
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
+1
-1
@@ -135,7 +135,7 @@ public class LazyClassDescriptor extends ClassDescriptorBase implements ClassDes
|
||||
this.kind = classLikeInfo.getClassKind();
|
||||
this.staticScope = kind == ClassKind.ENUM_CLASS ?
|
||||
new StaticScopeForKotlinEnum(
|
||||
storageManager, this
|
||||
storageManager, this, /* enumEntriesCanBeUsed = */ true
|
||||
) : MemberScope.Empty.INSTANCE;
|
||||
|
||||
this.typeConstructor = new LazyClassTypeConstructor();
|
||||
|
||||
+7
-1
@@ -21,6 +21,7 @@ import org.jetbrains.kotlin.library.unresolvedDependencies
|
||||
import org.jetbrains.kotlin.name.FqName
|
||||
import org.jetbrains.kotlin.name.Name
|
||||
import org.jetbrains.kotlin.name.parentOrNull
|
||||
import org.jetbrains.kotlin.platform.jvm.isJvm
|
||||
import org.jetbrains.kotlin.resolve.CompilerDeserializationConfiguration
|
||||
import org.jetbrains.kotlin.resolve.sam.SamConversionResolverImpl
|
||||
import org.jetbrains.kotlin.serialization.deserialization.*
|
||||
@@ -152,6 +153,10 @@ class KlibMetadataModuleDescriptorFactoryImpl(
|
||||
KlibMetadataSerializerProtocol
|
||||
)
|
||||
|
||||
val enumEntriesDeserializationSupport = object : EnumEntriesDeserializationSupport {
|
||||
override fun canSynthesizeEnumEntries(): Boolean = moduleDescriptor.platform.isJvm()
|
||||
}
|
||||
|
||||
val components = DeserializationComponents(
|
||||
storageManager,
|
||||
moduleDescriptor,
|
||||
@@ -168,7 +173,8 @@ class KlibMetadataModuleDescriptorFactoryImpl(
|
||||
ContractDeserializerImpl(configuration, storageManager),
|
||||
extensionRegistryLite = KlibMetadataSerializerProtocol.extensionRegistry,
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList()),
|
||||
platformDependentTypeTransformer = platformDependentTypeTransformer
|
||||
platformDependentTypeTransformer = platformDependentTypeTransformer,
|
||||
enumEntriesDeserializationSupport = enumEntriesDeserializationSupport,
|
||||
)
|
||||
|
||||
fragmentsToInitialize.forEach {
|
||||
|
||||
+2
-1
@@ -52,7 +52,8 @@ class JvmBuiltInsPackageFragmentProvider(
|
||||
additionalClassPartsProvider, platformDependentDeclarationFilter,
|
||||
BuiltInSerializerProtocol.extensionRegistry,
|
||||
kotlinTypeChecker,
|
||||
samConversionResolver
|
||||
samConversionResolver,
|
||||
enumEntriesDeserializationSupport = JvmEnumEntriesDeserializationSupport,
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
+3
-6
@@ -27,11 +27,7 @@ import org.jetbrains.kotlin.descriptors.deserialization.PlatformDependentDeclara
|
||||
import org.jetbrains.kotlin.descriptors.impl.CompositePackageFragmentProvider
|
||||
import org.jetbrains.kotlin.descriptors.impl.ModuleDescriptorImpl
|
||||
import org.jetbrains.kotlin.incremental.components.LookupTracker
|
||||
import org.jetbrains.kotlin.load.java.AnnotationTypeQualifierResolver
|
||||
import org.jetbrains.kotlin.load.java.JavaClassFinder
|
||||
import org.jetbrains.kotlin.load.java.JavaClassesTracker
|
||||
import org.jetbrains.kotlin.load.java.JavaModuleAnnotationsProvider
|
||||
import org.jetbrains.kotlin.load.java.JavaTypeEnhancementState
|
||||
import org.jetbrains.kotlin.load.java.*
|
||||
import org.jetbrains.kotlin.load.java.components.JavaPropertyInitializerEvaluator
|
||||
import org.jetbrains.kotlin.load.java.components.JavaResolverCache
|
||||
import org.jetbrains.kotlin.load.java.components.SignaturePropagator
|
||||
@@ -82,7 +78,8 @@ class DeserializationComponentsForJava(
|
||||
platformDependentDeclarationFilter = jvmBuiltIns?.customizer ?: PlatformDependentDeclarationFilter.NoPlatformDependent,
|
||||
extensionRegistryLite = JvmProtoBufUtil.EXTENSION_REGISTRY,
|
||||
kotlinTypeChecker = kotlinTypeChecker, samConversionResolver = SamConversionResolverImpl(storageManager, emptyList()),
|
||||
typeAttributeTranslators = typeAttributeTranslators.translators
|
||||
typeAttributeTranslators = typeAttributeTranslators.translators,
|
||||
enumEntriesDeserializationSupport = JvmEnumEntriesDeserializationSupport,
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
+8
-2
@@ -31,7 +31,8 @@ import org.jetbrains.kotlin.utils.SmartList
|
||||
// We don't need to track lookups here since this scope used only for introduce special Enum class members
|
||||
class StaticScopeForKotlinEnum(
|
||||
storageManager: StorageManager,
|
||||
private val containingClass: ClassDescriptor
|
||||
private val containingClass: ClassDescriptor,
|
||||
private val enumEntriesCanBeUsed: Boolean,
|
||||
) : MemberScopeImpl() {
|
||||
init {
|
||||
assert(containingClass.kind == ClassKind.ENUM_CLASS) { "Class should be an enum: $containingClass" }
|
||||
@@ -44,7 +45,12 @@ class StaticScopeForKotlinEnum(
|
||||
}
|
||||
|
||||
private val properties: List<PropertyDescriptor> by storageManager.createLazyValue {
|
||||
listOfNotNull(createEnumEntriesProperty(containingClass))
|
||||
if (enumEntriesCanBeUsed) {
|
||||
// It still might be filtered out later in tower resolve if feature disabled
|
||||
listOfNotNull(createEnumEntriesProperty(containingClass))
|
||||
} else {
|
||||
emptyList()
|
||||
}
|
||||
}
|
||||
|
||||
override fun getContributedDescriptors(kindFilter: DescriptorKindFilter, nameFilter: (Name) -> Boolean) = functions + properties
|
||||
|
||||
+25
@@ -0,0 +1,25 @@
|
||||
/*
|
||||
* Copyright 2010-2023 JetBrains s.r.o. and Kotlin Programming Language contributors.
|
||||
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
|
||||
*/
|
||||
|
||||
package org.jetbrains.kotlin.serialization.deserialization
|
||||
|
||||
interface EnumEntriesDeserializationSupport {
|
||||
/**
|
||||
* Determines whether `Enum.entries` property can be synthesized for enums in this module,
|
||||
* when this property is not present in compiled code.
|
||||
* Returns `null` if it's not known.
|
||||
*/
|
||||
fun canSynthesizeEnumEntries(): Boolean?
|
||||
|
||||
object Default : EnumEntriesDeserializationSupport {
|
||||
override fun canSynthesizeEnumEntries(): Boolean? = null
|
||||
}
|
||||
}
|
||||
|
||||
object JvmEnumEntriesDeserializationSupport : EnumEntriesDeserializationSupport {
|
||||
|
||||
// In JVM modules "entries" can be called even on enum compiled without this property.
|
||||
override fun canSynthesizeEnumEntries(): Boolean = true
|
||||
}
|
||||
+2
-1
@@ -55,7 +55,8 @@ class DeserializationComponents(
|
||||
val kotlinTypeChecker: NewKotlinTypeChecker = NewKotlinTypeChecker.Default,
|
||||
val samConversionResolver: SamConversionResolver,
|
||||
val platformDependentTypeTransformer: PlatformDependentTypeTransformer = PlatformDependentTypeTransformer.None,
|
||||
val typeAttributeTranslators: List<TypeAttributeTranslator> = listOf(DefaultTypeAttributeTranslator)
|
||||
val typeAttributeTranslators: List<TypeAttributeTranslator> = listOf(DefaultTypeAttributeTranslator),
|
||||
val enumEntriesDeserializationSupport: EnumEntriesDeserializationSupport = EnumEntriesDeserializationSupport.Default,
|
||||
) {
|
||||
val classDeserializer: ClassDeserializer = ClassDeserializer(this)
|
||||
|
||||
|
||||
+6
-3
@@ -53,10 +53,13 @@ class DeserializedClassDescriptor(
|
||||
)
|
||||
|
||||
private val staticScope =
|
||||
if (kind == ClassKind.ENUM_CLASS)
|
||||
StaticScopeForKotlinEnum(c.storageManager, this)
|
||||
else
|
||||
if (kind == ClassKind.ENUM_CLASS) {
|
||||
val enumEntriesCanBeUsed = Flags.HAS_ENUM_ENTRIES.get(classProto.flags) ||
|
||||
c.components.enumEntriesDeserializationSupport.canSynthesizeEnumEntries() == true
|
||||
StaticScopeForKotlinEnum(c.storageManager, this, enumEntriesCanBeUsed)
|
||||
} else {
|
||||
MemberScope.Empty
|
||||
}
|
||||
|
||||
private val typeConstructor = DeserializedClassTypeConstructor()
|
||||
|
||||
|
||||
+6
-1
@@ -64,6 +64,10 @@ fun createKotlinJavascriptPackageFragmentProvider(
|
||||
|
||||
val notFoundClasses = NotFoundClasses(storageManager, module)
|
||||
|
||||
val enumEntriesDeserializationSupport = object : EnumEntriesDeserializationSupport {
|
||||
override fun canSynthesizeEnumEntries(): Boolean = false
|
||||
}
|
||||
|
||||
val components = DeserializationComponents(
|
||||
storageManager,
|
||||
module,
|
||||
@@ -80,7 +84,8 @@ fun createKotlinJavascriptPackageFragmentProvider(
|
||||
ContractDeserializerImpl(configuration, storageManager),
|
||||
platformDependentDeclarationFilter = PlatformDependentDeclarationFilter.NoPlatformDependent,
|
||||
extensionRegistryLite = JsSerializerProtocol.extensionRegistry,
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList())
|
||||
samConversionResolver = SamConversionResolverImpl(storageManager, samWithReceiverResolvers = emptyList()),
|
||||
enumEntriesDeserializationSupport = enumEntriesDeserializationSupport,
|
||||
)
|
||||
|
||||
for (packageFragment in packageFragments.filterIsInstance<KotlinJavascriptPackageFragment>()) {
|
||||
|
||||
Reference in New Issue
Block a user