JVM_IR: Optimize null checks.
Introduce lowering to remove null checks for primitive type expressions and replace them with true/false. Side-effects are preserved. Generate ifnull/ifnonnull instructions for null checks instead of materializing a null literal for an equality check.
This commit is contained in:
committed by
Mikhael Bogdanov
parent
f5312f42c5
commit
690b8e0ac9
-1
@@ -1,4 +1,3 @@
|
||||
// IGNORE_BACKEND: JVM_IR
|
||||
fun test(x: String?) {
|
||||
if (x == null) return
|
||||
|
||||
|
||||
-1
@@ -1,4 +1,3 @@
|
||||
// IGNORE_BACKEND: JVM_IR
|
||||
fun test1() {
|
||||
val a = null
|
||||
|
||||
|
||||
-1
@@ -1,4 +1,3 @@
|
||||
// IGNORE_BACKEND: JVM_IR
|
||||
fun test1() {
|
||||
val a = Unit
|
||||
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
// IGNORE_BACKEND: JVM_IR
|
||||
fun test() {
|
||||
val value = System.getProperty("key")
|
||||
if (value != null) {
|
||||
|
||||
Vendored
-1
@@ -1,4 +1,3 @@
|
||||
// IGNORE_BACKEND: JVM_IR
|
||||
fun almostAlwaysTrue() = true
|
||||
|
||||
fun runNoInline(f: () -> Unit) = f()
|
||||
|
||||
+1
@@ -1,3 +1,4 @@
|
||||
// IGNORE_BACKEND: JVM_IR
|
||||
fun test() {
|
||||
lateinit var z: String
|
||||
run {
|
||||
|
||||
+18
@@ -0,0 +1,18 @@
|
||||
fun f() : Int {
|
||||
return 42
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
if (f() == null) {
|
||||
return "fail 1"
|
||||
}
|
||||
|
||||
if (f() != null) {
|
||||
return "OK"
|
||||
}
|
||||
|
||||
return "fail 2"
|
||||
}
|
||||
|
||||
// 0 IF
|
||||
// 0 ACONST_NULL
|
||||
Reference in New Issue
Block a user