b193e708d3
There just should be a different facades for cases A<T1, T2> and foo<T1, T2>() Test data has changed for type alias constructors since previously, it was working by mistake because of assumption that type alias arguments are linearly mapped to the type parameters of the corresponding constructors ^KT-50703 Open
38 lines
1.4 KiB
Kotlin
Vendored
38 lines
1.4 KiB
Kotlin
Vendored
// !DIAGNOSTICS: -UNUSED_PARAMETER -UNUSED_VARIABLE
|
|
// !LANGUAGE: -TypeEnhancementImprovementsInStrictMode
|
|
// FULL_JDK
|
|
|
|
// FILE: MapLike.java
|
|
import java.util.Map;
|
|
|
|
public class MapLike<@org.jetbrains.annotations.NotNull K, V> {
|
|
void putAll(Map<K, V> map);
|
|
}
|
|
|
|
// FILE: ListLike.java
|
|
import java.util.Collection;
|
|
|
|
public class ListLike<K extends Collection<@org.jetbrains.annotations.NotNull Object>> {}
|
|
|
|
// FILE: main.kt
|
|
fun test0(map : MapLike<<!UPPER_BOUND_VIOLATED!>Int?<!>, Int>) {}
|
|
fun <K> test11(map : MapLike<<!UPPER_BOUND_VIOLATED!>K<!>, K>) {}
|
|
fun <K> test12(map : MapLike<<!UPPER_BOUND_VIOLATED!>K?<!>, K>) {}
|
|
fun <K : Any> test13(map : MapLike<K, K>) {}
|
|
fun <K : Any> test14(map : MapLike<<!UPPER_BOUND_VIOLATED!>K?<!>, K>) {}
|
|
|
|
class Foo<K>
|
|
|
|
typealias A<A> = MapLike<A, Int>
|
|
typealias A2<B> = Foo<MapLike<B, Int>>
|
|
typealias A3<C> = ListLike<List<C>>
|
|
|
|
fun main1(x: <!UPPER_BOUND_VIOLATED_IN_TYPEALIAS_EXPANSION!>A<Int?><!>) {}
|
|
fun main2(x: A2<Int?>) {}
|
|
fun main3(x: <!UPPER_BOUND_VIOLATED_IN_TYPEALIAS_EXPANSION!>A3<Int?><!>) {}
|
|
fun main3() {
|
|
val x = <!UPPER_BOUND_VIOLATED!>A3<Int?>()<!> // TODO: support reporting errors on typealias constructor calls
|
|
val x2 = <!UPPER_BOUND_VIOLATED!>A<Int?>()<!> // TODO: support reporting errors on typealias constructor calls
|
|
val y: <!UPPER_BOUND_VIOLATED_IN_TYPEALIAS_EXPANSION!>A3<Int?><!> = <!UPPER_BOUND_VIOLATED!>A3<Int?>()<!>
|
|
}
|