34e6649d31
Before this commit, nullable argument could match not null parameter. Now we require also correct nullability that breaks some cases
40 lines
588 B
Kotlin
Vendored
40 lines
588 B
Kotlin
Vendored
// !WITH_NEW_INFERENCE
|
|
//KT-2164 !! does not propagate nullability information
|
|
package kt2164
|
|
|
|
fun foo(x: Int): Int = x + 1
|
|
|
|
fun main() {
|
|
val x: Int? = null
|
|
|
|
<!INAPPLICABLE_CANDIDATE!>foo<!>(x)
|
|
|
|
if (x != null) {
|
|
foo(x)
|
|
foo(x!!)
|
|
foo(x)
|
|
}
|
|
|
|
<!INAPPLICABLE_CANDIDATE!>foo<!>(x)
|
|
|
|
if (x != null) {
|
|
foo(x)
|
|
foo(x!!)
|
|
foo(x)
|
|
} else {
|
|
<!INAPPLICABLE_CANDIDATE!>foo<!>(x)
|
|
foo(x!!)
|
|
foo(x)
|
|
}
|
|
|
|
foo(x)
|
|
foo(x!!)
|
|
foo(x)
|
|
|
|
val y: Int? = null
|
|
y!!
|
|
y!!
|
|
foo(y)
|
|
foo(y!!)
|
|
}
|