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
39 lines
1017 B
Kotlin
Vendored
39 lines
1017 B
Kotlin
Vendored
// TARGET_BACKEND: JVM
|
|
// WITH_STDLIB
|
|
// FULL_JDK
|
|
|
|
// MUTE_SIGNATURE_COMPARISON_K2: ANY
|
|
// ^ KT-57778
|
|
|
|
// FILE: OverloadResolutionResultsImpl.java
|
|
|
|
import java.util.*;
|
|
|
|
public class OverloadResolutionResultsImpl<D> {
|
|
public Collection<ResolvedCall<D>> getAllCandidates() {
|
|
return Collections.emptyList();
|
|
}
|
|
|
|
public void setAllCandidates(Collection<ResolvedCall<D>> allCandidates) {
|
|
}
|
|
|
|
public static <R> OverloadResolutionResultsImpl<R> nameNotFound() {
|
|
OverloadResolutionResultsImpl<R> results = new OverloadResolutionResultsImpl<>();
|
|
results.setAllCandidates(Collections.emptyList());
|
|
return results;
|
|
}
|
|
}
|
|
|
|
// FILE: AllCandidates.kt
|
|
|
|
class ResolvedCall<C>
|
|
|
|
class MyCandidate(val resolvedCall: ResolvedCall<*>)
|
|
|
|
private fun <A> allCandidatesResult(allCandidates: Collection<MyCandidate>) =
|
|
OverloadResolutionResultsImpl.nameNotFound<A>().apply {
|
|
this.allCandidates = allCandidates.map {
|
|
it.resolvedCall as ResolvedCall<A>
|
|
}
|
|
}
|