c7272f6986
Currently DFA does not set "definitely equal to null" for access to variables that got assigned `null`. For example, FIR should mark the following line as SENSELESS_COMPARISON due to `s = null` above. https://github.com/JetBrains/kotlin/blob/d1531f9cdd5852352c0133198706125dc63b6007/compiler/testData/diagnostics/tests/smartCasts/alwaysNull.fir.kt#L6 The problem is at https://github.com/JetBrains/kotlin/blob/7e9f27436a77de1c76e3705da7aa1fbe8938336b/compiler/fir/resolve/src/org/jetbrains/kotlin/fir/resolve/dfa/FirDataFlowAnalyzer.kt#L1104 For null assignment, ideally the type should be `Nothing?`. This is addressed in a followup commit instead.
57 lines
1.2 KiB
Kotlin
Vendored
57 lines
1.2 KiB
Kotlin
Vendored
// !LANGUAGE: +AllowContractsForCustomFunctions +UseReturnsEffect
|
|
// !USE_EXPERIMENTAL: kotlin.contracts.ExperimentalContracts
|
|
// !DIAGNOSTICS: -INVISIBLE_REFERENCE -INVISIBLE_MEMBER
|
|
|
|
import kotlin.contracts.*
|
|
|
|
fun nullWhenNull(x: Int?): Int? {
|
|
contract {
|
|
returnsNotNull() implies (x != null)
|
|
}
|
|
return x?.inc()
|
|
}
|
|
|
|
fun testNullWhenNull(x: Int?) {
|
|
if (nullWhenNull(x) == null) {
|
|
x<!UNSAFE_CALL!>.<!>dec()
|
|
}
|
|
else {
|
|
x.dec()
|
|
}
|
|
|
|
if (nullWhenNull(x) != null) {
|
|
x.dec()
|
|
}
|
|
else {
|
|
x<!UNSAFE_CALL!>.<!>dec()
|
|
}
|
|
|
|
x<!UNSAFE_CALL!>.<!>dec()
|
|
}
|
|
|
|
// NB. it is the same function as `nullWhenNull`, but annotations specifies other facet of the function behaviour
|
|
fun notNullWhenNotNull (x: Int?): Int? {
|
|
contract {
|
|
returns(null) implies (x == null)
|
|
}
|
|
return x?.inc()
|
|
}
|
|
|
|
fun testNotNullWhenNotNull (x: Int?) {
|
|
if (notNullWhenNotNull(x) == null) {
|
|
<!SENSELESS_COMPARISON!>x == null<!>
|
|
}
|
|
else {
|
|
x<!UNSAFE_CALL!>.<!>dec()
|
|
}
|
|
|
|
if (notNullWhenNotNull(x) != null) {
|
|
x<!UNSAFE_CALL!>.<!>dec()
|
|
}
|
|
else {
|
|
<!SENSELESS_COMPARISON!>x == null<!>
|
|
}
|
|
|
|
x<!UNSAFE_CALL!>.<!>dec()
|
|
}
|