6e8283a6fe
The reason #1 for this feature is that we want to test IdSignatures generated for declarations. Currently, there is no (easy) way to ensure that a change in the signature building logic doesn't cause any breaking changes wrt klibs. Now, most IdSignatures include hashed mangled names in them, so even if we catch a regression where the included hash changes, there would be no way of knowing immediately what caused it, unless we'd also have mangled names in the expectations. The reason #2 is to test the manglers themselves. Currently, there are no tests for them. They heavily duplicate each other, this is already causing issues (see KT-57427) that would be very hard to catch without these tests. ^KT-58238 Fixed
52 lines
1.3 KiB
Kotlin
Vendored
52 lines
1.3 KiB
Kotlin
Vendored
// WITH_STDLIB
|
|
// FULL_JDK
|
|
// JVM_TARGET: 1.8
|
|
// IGNORE_BACKEND: JS_IR
|
|
// IGNORE_BACKEND: JS_IR_ES6
|
|
|
|
// MUTE_SIGNATURE_COMPARISON_K2: ANY
|
|
// ^ KT-57429, KT-57788
|
|
|
|
interface SymbolOwner<E : SymbolOwner<E>>
|
|
|
|
interface Symbol<E : SymbolOwner<E>>
|
|
|
|
interface ReceiverValue {
|
|
val type: String
|
|
}
|
|
|
|
class ImplicitReceiverValue<S : Symbol<*>>(val boundSymbol: S?, override val type: String) : ReceiverValue
|
|
|
|
abstract class ImplicitReceiverStack : Iterable<ImplicitReceiverValue<*>> {
|
|
abstract operator fun get(name: String?): ImplicitReceiverValue<*>?
|
|
}
|
|
|
|
class PersistentImplicitReceiverStack(
|
|
private val stack: List<ImplicitReceiverValue<*>>
|
|
) : ImplicitReceiverStack(), Iterable<ImplicitReceiverValue<*>> {
|
|
override operator fun iterator(): Iterator<ImplicitReceiverValue<*>> {
|
|
return stack.iterator()
|
|
}
|
|
|
|
override operator fun get(name: String?): ImplicitReceiverValue<*>? {
|
|
return stack.lastOrNull()
|
|
}
|
|
}
|
|
|
|
fun bar(s: String) {}
|
|
|
|
fun foo(stack: PersistentImplicitReceiverStack) {
|
|
stack.forEach {
|
|
it.boundSymbol
|
|
bar(it.type)
|
|
}
|
|
}
|
|
|
|
fun box(): String {
|
|
val stack = PersistentImplicitReceiverStack(
|
|
listOf(ImplicitReceiverValue(null, "O"), ImplicitReceiverValue(null, "K"))
|
|
)
|
|
foo(stack)
|
|
return stack.first().type + stack[null]?.type
|
|
}
|