From 1a84927bfadc3ec59f3fdc61144a0417f7745226 Mon Sep 17 00:00:00 2001 From: Jon Amireh Date: Thu, 31 Oct 2024 10:46:16 -0700 Subject: [PATCH] Check for properties starting with 'is' (cherry picked from commit 37f3dc7046a718bc4a981577418d88e5271f9da5) --- .../com/google/devtools/ksp/impl/ResolverAAImpl.kt | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/kotlin-analysis-api/src/main/kotlin/com/google/devtools/ksp/impl/ResolverAAImpl.kt b/kotlin-analysis-api/src/main/kotlin/com/google/devtools/ksp/impl/ResolverAAImpl.kt index 344050f455..3dfaa123be 100644 --- a/kotlin-analysis-api/src/main/kotlin/com/google/devtools/ksp/impl/ResolverAAImpl.kt +++ b/kotlin-analysis-api/src/main/kotlin/com/google/devtools/ksp/impl/ResolverAAImpl.kt @@ -458,16 +458,18 @@ class ResolverAAImpl( return accessor.receiver.simpleName.asString() } - val prefix = if (accessor is KSPropertyGetter) { - "get" - } else { - "set" + val name = accessor.receiver.simpleName.asString() + val uppercasedName = name.replaceFirstChar(Char::uppercaseChar) + // https://kotlinlang.org/docs/java-to-kotlin-interop.html#properties + val prefixedName = when(accessor) { + is KSPropertyGetter -> if(name.startsWith("is")) name else "get$uppercasedName" + is KSPropertySetter -> if(name.startsWith("is")) "set${name.removePrefix("is")}" else "set$uppercasedName" + else -> "" } - val name = accessor.receiver.simpleName.asString().replaceFirstChar(Char::uppercaseChar) val inlineSuffix = symbol?.inlineSuffix ?: "" val mangledName = symbol?.internalSuffix ?: "" - return "$prefix$name$inlineSuffix$mangledName" + return "$prefixedName$inlineSuffix$mangledName" } // TODO: handle library symbols