816d89e393
This commits introduces testdata changes, where NI behaviour strictly improved, after several previous fixes. For some tests, just WITH_NEW_INFERENCE directive was added. It indicates, that some of previous commits first introduced error in that test, and then some other commit fixed it (netting no overall testdata change). It is preferrably to keep those annotations until we will migrate to NI completely, to prevent unexpected regressions.
42 lines
1.0 KiB
Kotlin
Vendored
42 lines
1.0 KiB
Kotlin
Vendored
// !WITH_NEW_INFERENCE
|
|
class A() {
|
|
operator infix fun plus(<!UNUSED_PARAMETER!>i<!> : Int) {}
|
|
operator fun unaryMinus() {}
|
|
operator infix fun contains(<!UNUSED_PARAMETER!>a<!> : Any?) : Boolean = true
|
|
}
|
|
|
|
operator infix fun A.div(<!UNUSED_PARAMETER!>i<!> : Int) {}
|
|
operator infix fun A?.times(<!UNUSED_PARAMETER!>i<!> : Int) {}
|
|
|
|
fun test(x : Int?, a : A?) {
|
|
x<!UNSAFE_CALL!>.<!>plus(1)
|
|
x?.plus(1)
|
|
x <!UNSAFE_OPERATOR_CALL!>+<!> 1
|
|
<!UNSAFE_CALL!>-<!>x
|
|
x<!UNSAFE_CALL!>.<!>unaryMinus()
|
|
x?.unaryMinus()
|
|
|
|
a<!UNSAFE_CALL!>.<!>plus(1)
|
|
a?.plus(1)
|
|
a <!UNSAFE_INFIX_CALL!>plus<!> 1
|
|
a <!UNSAFE_OPERATOR_CALL!>+<!> 1
|
|
<!UNSAFE_CALL!>-<!>a
|
|
a<!UNSAFE_CALL!>.<!>unaryMinus()
|
|
a?.unaryMinus()
|
|
|
|
a<!UNSAFE_CALL!>.<!>div(1)
|
|
a <!UNSAFE_OPERATOR_CALL!>/<!> 1
|
|
a <!UNSAFE_INFIX_CALL!>div<!> 1
|
|
a?.div(1)
|
|
|
|
a.times(1)
|
|
a * 1
|
|
a times 1
|
|
a?.times(1)
|
|
|
|
1 <!UNSAFE_OPERATOR_CALL!>in<!> a
|
|
a <!UNSAFE_INFIX_CALL!>contains<!> 1
|
|
a<!UNSAFE_CALL!>.<!>contains(1)
|
|
a?.contains(1)
|
|
}
|