105358dcf6
Let's call builder lambdas (BL) a lambda that has non-fixed input type projection at the moment of lambda arguments analysis, such lambdas is a subject to be analyzed with builder inference Due to bug in constraint system joining algorithm, currently system of two or more such lambdas may lead to unsound type inference Diagnostic added here should be reported in case when there are two BL that shares a common constraint system, while not annotated with @BuilderInference, as a protection against aforementioned bug It's reported by ConstraintSystemCompleter when such situation has occurred during builder inference phase, it is the same place that decides wherever lambdas is subject to builder inference or not KT-53740
224 lines
8.8 KiB
Kotlin
Vendored
224 lines
8.8 KiB
Kotlin
Vendored
// WITH_STDLIB
|
|
// !DIAGNOSTICS: -OPT_IN_USAGE_ERROR
|
|
// For FIR, see: KT-50704
|
|
import kotlin.experimental.ExperimentalTypeInference
|
|
|
|
@JvmName("foo1")
|
|
fun foo(x: Inv<String>) {}
|
|
fun foo(x: Inv<Int>) {}
|
|
|
|
@JvmName("foo21")
|
|
fun Inv<String>.foo2() {}
|
|
fun Inv<Int>.foo2() {}
|
|
|
|
@JvmName("bar1")
|
|
fun String.bar() {}
|
|
fun Int.bar() {}
|
|
|
|
class Inv<K>(x: K)
|
|
|
|
fun foo0(x: String, y: Float, z: String = "") {}
|
|
fun foo0(x: String, y: Float, z: Int = 1) {}
|
|
|
|
fun foo00(x: String, y: Number) {}
|
|
fun foo00(x: CharSequence, y: Float) {}
|
|
|
|
fun foo000(x: String, y: Number, z: String) {}
|
|
fun foo000(x: CharSequence, y: Float, z: Int) {}
|
|
|
|
fun foo0000(x: String, y: Number, z: String) {}
|
|
fun foo0000(x: Int, y: Float, z: Int) {}
|
|
|
|
fun foo0001(x: List<Int>, y: Number, z: String) {}
|
|
fun foo0001(x: String, y: Float, z: Int) {}
|
|
|
|
fun foo0002(x: Int, y: Number, z: String) {}
|
|
fun foo0002(x: String, y: Float, z: Int) {}
|
|
|
|
fun Int.foo0003(y: Number, z: String) {}
|
|
fun String.foo0003(y: Float, z: Int) {}
|
|
|
|
@JvmName("foo111")
|
|
fun foo11(x: MutableSet<MutableMap.MutableEntry<String, Int>>) {}
|
|
@JvmName("foo112")
|
|
fun foo11(x: MutableSet<MutableMap.MutableEntry<Int, String>>) {}
|
|
fun foo11(x: MutableSet<MutableMap.MutableEntry<Int, Int>>) {}
|
|
|
|
fun main() {
|
|
val list1 = buildList {
|
|
add("one")
|
|
|
|
val secondParameter = get(1)
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>println<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>secondParameter<!>) // ERROR: [OVERLOAD_RESOLUTION_AMBIGUITY] Overload resolution ambiguity. All these functions match.
|
|
}
|
|
val list2 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>println<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>get(1)<!>) // ERROR: [OVERLOAD_RESOLUTION_AMBIGUITY] Overload resolution ambiguity. All these functions match.
|
|
}
|
|
val list3 = buildList {
|
|
add("one")
|
|
|
|
val secondParameter = Inv(get(1))
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("Inv<String>; E; String")!>secondParameter<!>)
|
|
}
|
|
val list4 = buildList {
|
|
add("one")
|
|
|
|
val secondParameter = get(1)
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("Inv<String>; E; String")!>Inv(secondParameter)<!>)
|
|
}
|
|
val list5 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("Inv<String>; E; String")!>Inv(get(1))<!>)
|
|
}
|
|
val list6 = buildList {
|
|
add("one")
|
|
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; null")!>get(0)<!>.<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>bar<!>()
|
|
}
|
|
val list7 = buildList {
|
|
add("one")
|
|
|
|
with (get(0)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; null")!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>bar<!>()<!>
|
|
}
|
|
}
|
|
val list71 = buildList {
|
|
add("one")
|
|
|
|
with (get(0)) l1@ {
|
|
with (listOf(1)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; LAMBDA_EXPRESSION")!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>bar<!>()<!>
|
|
}
|
|
}
|
|
}
|
|
val list711 = buildList {
|
|
add("one")
|
|
|
|
with (get(0)) {
|
|
with (listOf(1)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; LAMBDA_EXPRESSION")!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>bar<!>()<!>
|
|
}
|
|
}
|
|
}
|
|
val list8 = buildList {
|
|
add("one")
|
|
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("Inv<String>; E; String; null")!>Inv(get(0))<!>.<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo2<!>()
|
|
}
|
|
val list9 = buildList {
|
|
add("one")
|
|
|
|
with (get(0)) {
|
|
with (Inv(this)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("Inv<String>; E; String; null")!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo2<!>()<!>
|
|
}
|
|
}
|
|
}
|
|
val list91 = buildList {
|
|
add("one")
|
|
|
|
with (get(0)) {
|
|
with (Inv(this)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; LAMBDA_EXPRESSION")!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>bar<!>()<!>
|
|
}
|
|
}
|
|
}
|
|
|
|
// Resolution ambiguities below aren't due to stub types
|
|
val list10 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY!>foo0<!>(get(0), 0f)
|
|
}
|
|
val list11 = buildList {
|
|
add("one")
|
|
|
|
val x = get(0)
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY!>foo0<!>(x, 0f)
|
|
}
|
|
val list12 = buildList {
|
|
add("one")
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY!>foo00<!>(get(0), 0f)
|
|
}
|
|
|
|
// Below are multi-arguments resolution ambiguities
|
|
val list13 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo000<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>get(0)<!>, 0f, <!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>get(0)<!>)
|
|
}
|
|
|
|
val list14 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo0000<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>get(0)<!>, 0f, <!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>get(0)<!>)
|
|
}
|
|
|
|
val list17 = buildList l1@ {
|
|
add("one")
|
|
|
|
with (get(0)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; null")!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo0003<!>(0f, <!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>this@l1.get(0)<!>)<!>
|
|
}
|
|
}
|
|
|
|
val list18 = buildList {
|
|
add("one")
|
|
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY("String; E; String; null")!>get(0)<!>.<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo0003<!>(0f, <!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("String; E; String")!>get(0)<!>)
|
|
}
|
|
|
|
val map1 = buildMap {
|
|
put(1, "one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo11<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY("MutableSet<MutableMap.MutableEntry<Int, String>>; K, V; Int, String")!>entries<!>)
|
|
}
|
|
|
|
// There aren't specific errors below as casting value arguments doesn't make a resolve successful
|
|
val list15 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY!>foo0001<!>(get(0), 0f, get(0))
|
|
}
|
|
|
|
val list16 = buildList {
|
|
add("one")
|
|
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY!>foo0002<!>(get(0), 0f, get(0))
|
|
}
|
|
}
|
|
|
|
interface Foo<K> {
|
|
fun add(x: K)
|
|
fun get(): K
|
|
}
|
|
|
|
interface Foo2<K, V> {
|
|
fun put(x: K, y: V)
|
|
fun get(): MutableSet<MutableMap.MutableEntry<K, V>>
|
|
fun entries(): MutableSet<MutableMap.MutableEntry<K, V>>
|
|
}
|
|
|
|
@OptIn(ExperimentalTypeInference::class)
|
|
fun <L, K, V> twoBuilderLambdas(@BuilderInference block: Foo<L>.() -> Unit, @BuilderInference block2: Foo2<K, V>.() -> Unit) {}
|
|
|
|
fun test() {
|
|
twoBuilderLambdas(
|
|
{
|
|
add("")
|
|
with (get()) {
|
|
with (listOf(1)) {
|
|
<!STUB_TYPE_IN_RECEIVER_CAUSES_AMBIGUITY!><!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>bar<!>()<!>
|
|
}
|
|
}
|
|
},
|
|
{
|
|
put(1, "one")
|
|
<!DEBUG_INFO_ELEMENT_WITH_ERROR_TYPE, OVERLOAD_RESOLUTION_AMBIGUITY, OVERLOAD_RESOLUTION_AMBIGUITY_BECAUSE_OF_STUB_TYPES!>foo11<!>(<!STUB_TYPE_IN_ARGUMENT_CAUSES_AMBIGUITY!>entries()<!>)
|
|
}
|
|
)
|
|
}
|