Files
kotlin-fork/compiler/testData/ir/irText/firProblems/Modality.sig.kt.txt
T
Sergej Jaskiewicz 6e8283a6fe [IR] Dump IdSignatures and mangled names in irText tests
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
2023-05-15 18:20:45 +00:00

91 lines
2.8 KiB
Kotlin
Vendored

// CHECK:
// Mangled name: Atom
// Public signature: /Atom|null[0]
class Atom {
// CHECK:
// Mangled name: Atom{}candidateDescriptor
// Public signature: /Atom.candidateDescriptor|-3112599931076785471[0]
val candidateDescriptor: CallableDescriptor
// CHECK JVM_IR:
// Mangled name: Atom#<get-candidateDescriptor>(){}CallableDescriptor
// Public signature: /Atom.candidateDescriptor.<get-candidateDescriptor>|4556132200066715385[0]
get
// CHECK:
// Mangled name: Atom#<init>(CallableDescriptor){}
// Public signature: /Atom.<init>|-1799222929165952555[0]
constructor(candidateDescriptor: CallableDescriptor) /* primary */
}
// CHECK:
// Mangled name: KotlinResolutionCandidate
// Public signature: /KotlinResolutionCandidate|null[0]
class KotlinResolutionCandidate {
// CHECK:
// Mangled name: KotlinResolutionCandidate{}resolvedCall
// Public signature: /KotlinResolutionCandidate.resolvedCall|-2429780263902948392[0]
val resolvedCall: Atom
// CHECK JVM_IR:
// Mangled name: KotlinResolutionCandidate#<get-resolvedCall>(){}Atom
// Public signature: /KotlinResolutionCandidate.resolvedCall.<get-resolvedCall>|49370572931497711[0]
get
// CHECK:
// Mangled name: KotlinResolutionCandidate#<init>(Atom){}
// Public signature: /KotlinResolutionCandidate.<init>|-8995219914817488939[0]
constructor(resolvedCall: Atom) /* primary */
}
// CHECK:
// Mangled name: ResolutionPart
// Public signature: /ResolutionPart|null[0]
abstract class ResolutionPart {
// CHECK:
// Mangled name: ResolutionPart#<init>(){}
// Public signature: /ResolutionPart.<init>|-5645683436151566731[0]
constructor() /* primary */
// CHECK JVM_IR:
// Mangled name: ResolutionPart#process@KotlinResolutionCandidate(){}kotlin.String
// Public signature: /ResolutionPart.process|8201571705428560068[0]
abstract fun KotlinResolutionCandidate.process(): String
}
// CHECK:
// Mangled name: Substitutable
// Public signature: /Substitutable|null[0]
interface Substitutable<out T : DeclarationDescriptorNonRoot> {
}
// CHECK:
// Mangled name: Final
// Public signature: /Final|null[0]
object Final : Modality {
// CHECK:
// Mangled name: Final#<init>(){}
// Public signature: /Final.<init>|-5645683436151566731[0]
private constructor() /* primary */
}
// CHECK:
// Mangled name: Owner
// Public signature: /Owner|null[0]
object Owner : ResolutionPart {
// CHECK:
// Mangled name: Owner#<init>(){}
// Public signature: /Owner.<init>|-5645683436151566731[0]
private constructor() /* primary */
// CHECK JVM_IR:
// Mangled name: Owner#process@KotlinResolutionCandidate(){}kotlin.String
// Public signature: /Owner.process|8201571705428560068[0]
override fun KotlinResolutionCandidate.process(): String
}