dc42b20ae3
The new inference uses inferred intersection types normally, unlike the old inference.
However, intersection types in public declarations are approximated to supertype, which
potentially may give a less presice type, then it would be with the OI.
For non-related T1, T2 the NI approximates {T1 & T2} to Any in public declarations,
and if the OI was inferring T1 instead of the intersection type, it may lead to
less precise declaration type and related errors.
The solution is to remember an alternative for an intersection type when present.
Before approximation the alternative replaces the intersection type.
^KT-36249 Fixed
19 lines
492 B
Kotlin
Vendored
19 lines
492 B
Kotlin
Vendored
// !DIAGNOSTICS: -UNUSED_PARAMETER UNUSED_VARIABLE -UNUSED_EXPRESSION
|
|
|
|
import kotlin.reflect.KClass
|
|
fun <T : PsiElement> select(vararg classes: KClass<out T>): T? {
|
|
return null
|
|
}
|
|
interface PomRenameableTarget
|
|
interface PsiElement
|
|
interface PsiMethod : PsiElement, PomRenameableTarget
|
|
interface PsiClass : PsiElement, PomRenameableTarget
|
|
|
|
class A {
|
|
val inv get() = select(PsiMethod::class, PsiClass::class)
|
|
}
|
|
|
|
fun main() {
|
|
<!DEBUG_INFO_EXPRESSION_TYPE("PsiElement?")!>A().inv<!>
|
|
}
|