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
24 lines
444 B
Kotlin
Vendored
24 lines
444 B
Kotlin
Vendored
// FIR_IDENTICAL
|
|
// WITH_STDLIB
|
|
// DUMP_LOCAL_DECLARATION_SIGNATURES
|
|
|
|
// MUTE_SIGNATURE_COMPARISON_K2: ANY
|
|
// ^ KT-57434
|
|
|
|
class MyClass(val value: String)
|
|
|
|
operator fun MyClass.provideDelegate(host: Any?, p: Any): String =
|
|
this.value
|
|
|
|
operator fun String.getValue(receiver: Any?, p: Any): String =
|
|
this
|
|
|
|
|
|
fun box(): String {
|
|
val testO by MyClass("O")
|
|
val testK by "K"
|
|
val testOK = testO + testK
|
|
|
|
return testOK
|
|
}
|