From fd30c59a91a4e1e20636ef92d7b73f32ba711c03 Mon Sep 17 00:00:00 2001 From: Ting-Yuan Huang Date: Mon, 11 Nov 2024 11:25:31 -0800 Subject: [PATCH 1/3] UPDATE_KOTLIN_VERSION: 2.1.20-dev-3305 --- .../test/kotlin/com/google/devtools/ksp/test/AbstractKSPTest.kt | 2 +- gradle.properties | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/compiler-plugin/src/test/kotlin/com/google/devtools/ksp/test/AbstractKSPTest.kt b/compiler-plugin/src/test/kotlin/com/google/devtools/ksp/test/AbstractKSPTest.kt index 826f5eff8c..78a3fff699 100644 --- a/compiler-plugin/src/test/kotlin/com/google/devtools/ksp/test/AbstractKSPTest.kt +++ b/compiler-plugin/src/test/kotlin/com/google/devtools/ksp/test/AbstractKSPTest.kt @@ -185,7 +185,7 @@ abstract class AbstractKSPTest(frontend: FrontendKind<*>) : DisposableTest() { "-classpath", classpath, "-d", module.outDir.path ) - compileJavaFiles(javaFiles, options, assertions = JUnit5Assertions) + compileJavaFiles(javaFiles, options) } fun runTest(@TestDataFile path: String) { diff --git a/gradle.properties b/gradle.properties index 36f155f1ae..480bc27fc4 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,7 +1,7 @@ # Copied from kotlinc org.gradle.jvmargs=-Duser.country=US -Dkotlin.daemon.jvm.options=-Xmx4096m -Dfile.encoding=UTF-8 -kotlinBaseVersion=2.1.0 +kotlinBaseVersion=2.1.20-dev-3305 agpBaseVersion=7.3.1 agpTestVersion=8.7.1 intellijVersion=233.13135.128 From ea1f3237eff1591231d93aa5c8c94be2aa7fbfa5 Mon Sep 17 00:00:00 2001 From: Jinseong Jeon Date: Thu, 12 Dec 2024 17:37:31 -0800 Subject: [PATCH 2/3] Adapt to removal of old JVM backend See https://youtrack.jetbrains.com/issue/KT-71197 Co-authored-by: Alexander Udalov --- .../ksp/processing/impl/ResolverImpl.kt | 65 +++++++++++++------ gradle.properties | 2 +- 2 files changed, 47 insertions(+), 20 deletions(-) diff --git a/compiler-plugin/src/main/kotlin/com/google/devtools/ksp/processing/impl/ResolverImpl.kt b/compiler-plugin/src/main/kotlin/com/google/devtools/ksp/processing/impl/ResolverImpl.kt index 44fd8744fc..cc3aebc4e8 100644 --- a/compiler-plugin/src/main/kotlin/com/google/devtools/ksp/processing/impl/ResolverImpl.kt +++ b/compiler-plugin/src/main/kotlin/com/google/devtools/ksp/processing/impl/ResolverImpl.kt @@ -57,7 +57,7 @@ import com.intellij.psi.impl.source.PsiClassReferenceType import org.jetbrains.kotlin.builtins.KotlinBuiltIns import org.jetbrains.kotlin.builtins.jvm.JavaToKotlinClassMap import org.jetbrains.kotlin.codegen.ClassBuilderMode -import org.jetbrains.kotlin.codegen.OwnerKind +import org.jetbrains.kotlin.codegen.signature.BothSignatureWriter import org.jetbrains.kotlin.codegen.state.KotlinTypeMapper import org.jetbrains.kotlin.config.LanguageVersionSettingsImpl import org.jetbrains.kotlin.container.ComponentProvider @@ -66,9 +66,11 @@ import org.jetbrains.kotlin.container.tryGetService import org.jetbrains.kotlin.descriptors.* import org.jetbrains.kotlin.descriptors.annotations.AnnotationDescriptor import org.jetbrains.kotlin.descriptors.annotations.Annotations +import org.jetbrains.kotlin.fileClasses.JvmFileClassUtil import org.jetbrains.kotlin.incremental.components.NoLookupLocation import org.jetbrains.kotlin.load.java.components.TypeUsage import org.jetbrains.kotlin.load.java.descriptors.JavaForKotlinOverridePropertyDescriptor +import org.jetbrains.kotlin.load.java.descriptors.getImplClassNameForDeserialized import org.jetbrains.kotlin.load.java.lazy.* import org.jetbrains.kotlin.load.java.lazy.descriptors.LazyJavaTypeParameterDescriptor import org.jetbrains.kotlin.load.java.lazy.types.JavaTypeResolver @@ -106,6 +108,7 @@ import org.jetbrains.kotlin.resolve.multiplatform.findExpects import org.jetbrains.kotlin.resolve.scopes.DescriptorKindFilter import org.jetbrains.kotlin.resolve.scopes.LexicalScope import org.jetbrains.kotlin.resolve.scopes.MemberScope +import org.jetbrains.kotlin.serialization.deserialization.descriptors.DescriptorWithContainerSource import org.jetbrains.kotlin.types.* import org.jetbrains.kotlin.types.checker.SimpleClassicTypeSystemContext import org.jetbrains.kotlin.types.typeUtil.replaceArgumentsWithStarProjections @@ -113,6 +116,7 @@ import org.jetbrains.kotlin.types.typeUtil.substitute import org.jetbrains.kotlin.types.typeUtil.supertypes import org.jetbrains.kotlin.util.containingNonLocalDeclaration import org.jetbrains.org.objectweb.asm.Opcodes +import org.jetbrains.org.objectweb.asm.Type import java.io.File import java.util.* @@ -356,20 +360,28 @@ class ResolverImpl( override fun mapToJvmSignature(declaration: KSDeclaration): String? = mapToJvmSignatureInternal(declaration) internal fun mapToJvmSignatureInternal(declaration: KSDeclaration): String? = when (declaration) { - is KSClassDeclaration -> resolveClassDeclaration(declaration)?.let { typeMapper.mapType(it).descriptor } + is KSClassDeclaration -> resolveClassDeclaration(declaration)?.let { + typeMapper.mapType(it.defaultType).descriptor + } is KSFunctionDeclaration -> resolveFunctionDeclaration(declaration)?.let { when (it) { is FunctionDescriptor -> typeMapper.mapAsmMethod(it).descriptor - is PropertyDescriptor -> typeMapper.mapFieldSignature(it.type, it) ?: typeMapper.mapType(it).descriptor + is PropertyDescriptor -> typeMapper.mapPropertySignature(it) else -> throw IllegalStateException("Unexpected descriptor type for declaration: $declaration") } } is KSPropertyDeclaration -> resolvePropertyDeclaration(declaration)?.let { - typeMapper.mapFieldSignature(it.type, it) ?: typeMapper.mapType(it).descriptor + typeMapper.mapPropertySignature(it) } else -> null } + private fun KotlinTypeMapper.mapPropertySignature(descriptor: PropertyDescriptor): String? { + val sw = BothSignatureWriter(BothSignatureWriter.Mode.TYPE) + writeFieldSignature(descriptor.type, descriptor, sw) + return sw.makeJavaGenericSignature() ?: mapType(descriptor.type).descriptor + } + override fun overrides(overrider: KSDeclaration, overridee: KSDeclaration): Boolean { fun resolveForOverride(declaration: KSDeclaration): DeclarationDescriptor? { return when (declaration) { @@ -880,22 +892,13 @@ class ResolverImpl( @KspExperimental override fun getJvmName(accessor: KSPropertyAccessor): String? { - val descriptor = resolvePropertyAccessorDeclaration(accessor) - - return descriptor?.let { - // KotlinTypeMapper.mapSignature always uses OwnerKind.IMPLEMENTATION - typeMapper.mapFunctionName(descriptor, OwnerKind.IMPLEMENTATION) - } + return resolvePropertyAccessorDeclaration(accessor)?.let(typeMapper::mapFunctionName) } @KspExperimental override fun getJvmName(declaration: KSFunctionDeclaration): String? { // function names might be mangled if they receive inline class parameters or they are internal - val descriptor = resolveFunctionDeclaration(declaration) - return (descriptor as? FunctionDescriptor)?.let { - // KotlinTypeMapper.mapSignature always uses OwnerKind.IMPLEMENTATION - typeMapper.mapFunctionName(it, OwnerKind.IMPLEMENTATION) - } + return (resolveFunctionDeclaration(declaration) as? FunctionDescriptor)?.let(typeMapper::mapFunctionName) } @KspExperimental @@ -911,11 +914,35 @@ class ResolverImpl( } private fun getJvmOwnerQualifiedName(descriptor: DeclarationDescriptor): String? { - return try { - typeMapper.mapImplementationOwner(descriptor).className - } catch (unsupported: UnsupportedOperationException) { - null + return typeMapper.mapJvmImplementationOwner(descriptor)?.className + } + + private fun KotlinTypeMapper.mapJvmImplementationOwner(descriptor: DeclarationDescriptor): Type? { + if (descriptor is ConstructorDescriptor) { + return mapClass(descriptor.constructedClass) } + + return when (val container = descriptor.containingDeclaration) { + is PackageFragmentDescriptor -> + internalNameForPackageMemberOwner(descriptor as CallableMemberDescriptor)?.let(Type::getObjectType) + is ClassDescriptor -> + mapClass(container) + else -> null + } + } + + private fun internalNameForPackageMemberOwner(descriptor: CallableMemberDescriptor): String? { + val file = DescriptorToSourceUtils.getContainingFile(descriptor) + if (file != null) { + return JvmFileClassUtil.getFileClassInternalName(file) + } + + val directMember = DescriptorUtils.getDirectMember(descriptor) + if (directMember is DescriptorWithContainerSource) { + return directMember.getImplClassNameForDeserialized()?.internalName + } + + return null } // TODO: refactor and reuse BinaryClassInfoCache diff --git a/gradle.properties b/gradle.properties index 480bc27fc4..2d97771bc9 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,7 +1,7 @@ # Copied from kotlinc org.gradle.jvmargs=-Duser.country=US -Dkotlin.daemon.jvm.options=-Xmx4096m -Dfile.encoding=UTF-8 -kotlinBaseVersion=2.1.20-dev-3305 +kotlinBaseVersion=2.1.20-dev-5634 agpBaseVersion=7.3.1 agpTestVersion=8.7.1 intellijVersion=233.13135.128 From 1ef81698e644272dc4031a65397f01f93817f7bf Mon Sep 17 00:00:00 2001 From: Jinseong Jeon Date: Thu, 19 Dec 2024 20:05:00 -0800 Subject: [PATCH 3/3] Bump Kotlin version to 2.1.20-Beta1 --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index 2d97771bc9..32c1565b2d 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,7 +1,7 @@ # Copied from kotlinc org.gradle.jvmargs=-Duser.country=US -Dkotlin.daemon.jvm.options=-Xmx4096m -Dfile.encoding=UTF-8 -kotlinBaseVersion=2.1.20-dev-5634 +kotlinBaseVersion=2.1.20-Beta1 agpBaseVersion=7.3.1 agpTestVersion=8.7.1 intellijVersion=233.13135.128