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
48 lines
1.2 KiB
Kotlin
Vendored
48 lines
1.2 KiB
Kotlin
Vendored
// CHECK:
|
|
// Mangled name: A
|
|
// Public signature: /A|null[0]
|
|
open annotation class A : Annotation {
|
|
// CHECK:
|
|
// Mangled name: A{}x
|
|
// Public signature: /A.x|-8060530855978347579[0]
|
|
val x: Int
|
|
// CHECK JVM_IR:
|
|
// Mangled name: A#<get-x>(){}kotlin.Int
|
|
// Public signature: /A.x.<get-x>|4966956098150895696[0]
|
|
// CHECK JS_IR NATIVE:
|
|
// Mangled name: A#<get-x>(){}
|
|
// Public signature: /A.x.<get-x>|1482705010654679335[0]
|
|
get
|
|
|
|
// CHECK:
|
|
// Mangled name: A#<init>(kotlin.Int){}
|
|
// Public signature: /A.<init>|-5182794243525578284[0]
|
|
constructor(x: Int) /* primary */
|
|
|
|
}
|
|
|
|
// CHECK:
|
|
// Mangled name: #test1(){}
|
|
// Public signature: /test1|4297044443957252634[0]
|
|
@A(x = 1)
|
|
fun test1(): Unit
|
|
|
|
// CHECK:
|
|
// Mangled name: #test2(){}
|
|
// Public signature: /test2|4279114864133353152[0]
|
|
@A(x = 2)
|
|
fun test2(): Unit
|
|
|
|
// CHECK:
|
|
// Mangled name: {}ONE
|
|
// Public signature: /ONE|5698484753436154102[0]
|
|
const val ONE: Int
|
|
// CHECK JVM_IR:
|
|
// Mangled name: #<get-ONE>(){}kotlin.Int
|
|
// Public signature: /ONE.<get-ONE>|7844388037784691246[0]
|
|
// CHECK JS_IR NATIVE:
|
|
// Mangled name: #<get-ONE>(){}
|
|
// Public signature: /ONE.<get-ONE>|6594203029520379115[0]
|
|
get
|
|
|