02b40326cc
If all the suspension calls in a suspend function were "hidden" under the for-convention (iterator/next/hasNext) calls, control-flow didn't find them, thus supposing that there is no suspension points and there is no need to generate a coroutine state machine The solution is to add relevant calls to CFG #KT-15824 Fixed
470 lines
31 KiB
Plaintext
Vendored
470 lines
31 KiB
Plaintext
Vendored
== t1 ==
|
|
fun t1() {
|
|
try {
|
|
1
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
1 <v0>: * NEW: r(1) -> <v0>
|
|
{ 1 } <v0>: * COPY
|
|
2 <v1>: * NEW: r(2) -> <v1>
|
|
{ 2 } <v1>: * COPY
|
|
try { 1 } finally { 2 } <v2>: * NEW: merge(try { 1 } finally { 2 }|<v0>) -> <v2>
|
|
{ try { 1 } finally { 2 } } <v2>: * COPY
|
|
=====================
|
|
== t2 ==
|
|
fun t2() {
|
|
try {
|
|
1
|
|
if (2 > 3) {
|
|
return
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
1 <v0>: * NEW: r(1) -> <v0>
|
|
2 <v1>: {<: Comparable<Int>} NEW: r(2) -> <v1>
|
|
3 <v2>: Int NEW: r(3) -> <v2>
|
|
2 > 3 <v3>: Boolean NEW: call(2 > 3, compareTo|<v1>, <v2>) -> <v3>
|
|
return !<v5>: *
|
|
{ return } !<v5>: * COPY
|
|
if (2 > 3) { return } <v6>: * NEW: merge(if (2 > 3) { return }|!<v5>) -> <v6>
|
|
{ 1 if (2 > 3) { return } } <v6>: * COPY
|
|
2 <v4>: * NEW: r(2) -> <v4>
|
|
{ 2 } <v4>: * COPY
|
|
try { 1 if (2 > 3) { return } } finally { 2 } <v7>: * NEW: merge(try { 1 if (2 > 3) { return } } finally { 2 }|<v6>) -> <v7>
|
|
{ try { 1 if (2 > 3) { return } } finally { 2 } } <v7>: * COPY
|
|
=====================
|
|
== t3 ==
|
|
fun t3() {
|
|
try {
|
|
1
|
|
l@{ ->
|
|
if (2 > 3) {
|
|
return@l
|
|
}
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
1 <v0>: * NEW: r(1) -> <v0>
|
|
{ -> if (2 > 3) { return@l } } <v1>: * NEW: r({ -> if (2 > 3) { return@l } }) -> <v1>
|
|
l@{ -> if (2 > 3) { return@l } } <v1>: * COPY
|
|
{ 1 l@{ -> if (2 > 3) { return@l } } } <v1>: * COPY
|
|
2 <v2>: * NEW: r(2) -> <v2>
|
|
{ 2 } <v2>: * COPY
|
|
try { 1 l@{ -> if (2 > 3) { return@l } } } finally { 2 } <v3>: * NEW: merge(try { 1 l@{ -> if (2 > 3) { return@l } } } finally { 2 }|<v1>) -> <v3>
|
|
{ try { 1 l@{ -> if (2 > 3) { return@l } } } finally { 2 } } <v3>: * COPY
|
|
=====================
|
|
== anonymous_0 ==
|
|
{ ->
|
|
if (2 > 3) {
|
|
return@l
|
|
}
|
|
}
|
|
---------------------
|
|
2 <v0>: {<: Comparable<Int>} NEW: r(2) -> <v0>
|
|
3 <v1>: Int NEW: r(3) -> <v1>
|
|
2 > 3 <v2>: Boolean NEW: call(2 > 3, compareTo|<v0>, <v1>) -> <v2>
|
|
return@l !<v3>: *
|
|
{ return@l } !<v3>: * COPY
|
|
if (2 > 3) { return@l } <v4>: * NEW: merge(if (2 > 3) { return@l }|!<v3>) -> <v4>
|
|
if (2 > 3) { return@l } <v4>: * COPY
|
|
=====================
|
|
== t4 ==
|
|
fun t4() {
|
|
l@{ ->
|
|
try {
|
|
1
|
|
if (2 > 3) {
|
|
return@l
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
}
|
|
---------------------
|
|
{ -> try { 1 if (2 > 3) { return@l } } finally { 2 } } <v0>: * NEW: r({ -> try { 1 if (2 > 3) { return@l } } finally { 2 } }) -> <v0>
|
|
l@{ -> try { 1 if (2 > 3) { return@l } } finally { 2 } } <v0>: * COPY
|
|
{ l@{ -> try { 1 if (2 > 3) { return@l } } finally { 2 } } } <v0>: * COPY
|
|
=====================
|
|
== anonymous_1 ==
|
|
{ ->
|
|
try {
|
|
1
|
|
if (2 > 3) {
|
|
return@l
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
1 <v0>: * NEW: r(1) -> <v0>
|
|
2 <v1>: {<: Comparable<Int>} NEW: r(2) -> <v1>
|
|
3 <v2>: Int NEW: r(3) -> <v2>
|
|
2 > 3 <v3>: Boolean NEW: call(2 > 3, compareTo|<v1>, <v2>) -> <v3>
|
|
return@l !<v5>: *
|
|
{ return@l } !<v5>: * COPY
|
|
if (2 > 3) { return@l } <v6>: * NEW: merge(if (2 > 3) { return@l }|!<v5>) -> <v6>
|
|
{ 1 if (2 > 3) { return@l } } <v6>: * COPY
|
|
2 <v4>: * NEW: r(2) -> <v4>
|
|
{ 2 } <v4>: * COPY
|
|
try { 1 if (2 > 3) { return@l } } finally { 2 } <v7>: * NEW: merge(try { 1 if (2 > 3) { return@l } } finally { 2 }|<v6>) -> <v7>
|
|
try { 1 if (2 > 3) { return@l } } finally { 2 } <v7>: * COPY
|
|
=====================
|
|
== t5 ==
|
|
fun t5() {
|
|
l@ while(true) {
|
|
try {
|
|
1
|
|
if (2 > 3) {
|
|
break@l
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
}
|
|
---------------------
|
|
<v1>: * NEW: magic[VALUE_CONSUMER](true|<v0>) -> <v1>
|
|
true <v0>: Boolean NEW: r(true) -> <v0>
|
|
1 <v2>: * NEW: r(1) -> <v2>
|
|
2 <v3>: {<: Comparable<Int>} NEW: r(2) -> <v3>
|
|
3 <v4>: Int NEW: r(3) -> <v4>
|
|
2 > 3 <v5>: Boolean NEW: call(2 > 3, compareTo|<v3>, <v4>) -> <v5>
|
|
break@l !<v7>: *
|
|
{ break@l } !<v7>: * COPY
|
|
if (2 > 3) { break@l } <v8>: * NEW: merge(if (2 > 3) { break@l }|!<v7>) -> <v8>
|
|
{ 1 if (2 > 3) { break@l } } <v8>: * COPY
|
|
2 <v6>: * NEW: r(2) -> <v6>
|
|
{ 2 } <v6>: * COPY
|
|
try { 1 if (2 > 3) { break@l } } finally { 2 } <v9>: * NEW: merge(try { 1 if (2 > 3) { break@l } } finally { 2 }|<v8>) -> <v9>
|
|
{ try { 1 if (2 > 3) { break@l } } finally { 2 } } <v9>: * COPY
|
|
while(true) { try { 1 if (2 > 3) { break@l } } finally { 2 } } !<v10>: *
|
|
l@ while(true) { try { 1 if (2 > 3) { break@l } } finally { 2 } } !<v10>: * COPY
|
|
{ l@ while(true) { try { 1 if (2 > 3) { break@l } } finally { 2 } } } !<v10>: * COPY
|
|
=====================
|
|
== t6 ==
|
|
fun t6() {
|
|
try {
|
|
l@ while(true) {
|
|
1
|
|
if (2 > 3) {
|
|
break@l
|
|
}
|
|
}
|
|
5
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
<v1>: * NEW: magic[VALUE_CONSUMER](true|<v0>) -> <v1>
|
|
true <v0>: Boolean NEW: r(true) -> <v0>
|
|
1 <v2>: * NEW: r(1) -> <v2>
|
|
2 <v3>: {<: Comparable<Int>} NEW: r(2) -> <v3>
|
|
3 <v4>: Int NEW: r(3) -> <v4>
|
|
2 > 3 <v5>: Boolean NEW: call(2 > 3, compareTo|<v3>, <v4>) -> <v5>
|
|
break@l !<v6>: *
|
|
{ break@l } !<v6>: * COPY
|
|
if (2 > 3) { break@l } <v7>: * NEW: merge(if (2 > 3) { break@l }|!<v6>) -> <v7>
|
|
{ 1 if (2 > 3) { break@l } } <v7>: * COPY
|
|
while(true) { 1 if (2 > 3) { break@l } } !<v8>: *
|
|
l@ while(true) { 1 if (2 > 3) { break@l } } !<v8>: * COPY
|
|
5 <v9>: * NEW: r(5) -> <v9>
|
|
{ l@ while(true) { 1 if (2 > 3) { break@l } } 5 } <v9>: * COPY
|
|
2 <v10>: * NEW: r(2) -> <v10>
|
|
{ 2 } <v10>: * COPY
|
|
try { l@ while(true) { 1 if (2 > 3) { break@l } } 5 } finally { 2 } <v11>: * NEW: merge(try { l@ while(true) { 1 if (2 > 3) { break@l } } 5 } finally { 2 }|<v9>) -> <v11>
|
|
{ try { l@ while(true) { 1 if (2 > 3) { break@l } } 5 } finally { 2 } } <v11>: * COPY
|
|
=====================
|
|
== t7 ==
|
|
fun t7() {
|
|
try {
|
|
l@ while(true) {
|
|
1
|
|
if (2 > 3) {
|
|
break@l
|
|
}
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
<v1>: * NEW: magic[VALUE_CONSUMER](true|<v0>) -> <v1>
|
|
true <v0>: Boolean NEW: r(true) -> <v0>
|
|
1 <v2>: * NEW: r(1) -> <v2>
|
|
2 <v3>: {<: Comparable<Int>} NEW: r(2) -> <v3>
|
|
3 <v4>: Int NEW: r(3) -> <v4>
|
|
2 > 3 <v5>: Boolean NEW: call(2 > 3, compareTo|<v3>, <v4>) -> <v5>
|
|
break@l !<v6>: *
|
|
{ break@l } !<v6>: * COPY
|
|
if (2 > 3) { break@l } <v7>: * NEW: merge(if (2 > 3) { break@l }|!<v6>) -> <v7>
|
|
{ 1 if (2 > 3) { break@l } } <v7>: * COPY
|
|
while(true) { 1 if (2 > 3) { break@l } } !<v8>: *
|
|
l@ while(true) { 1 if (2 > 3) { break@l } } !<v8>: * COPY
|
|
{ l@ while(true) { 1 if (2 > 3) { break@l } } } !<v8>: * COPY
|
|
2 <v9>: * NEW: r(2) -> <v9>
|
|
{ 2 } <v9>: * COPY
|
|
try { l@ while(true) { 1 if (2 > 3) { break@l } } } finally { 2 } <v10>: * NEW: merge(try { l@ while(true) { 1 if (2 > 3) { break@l } } } finally { 2 }|!<v8>) -> <v10>
|
|
{ try { l@ while(true) { 1 if (2 > 3) { break@l } } } finally { 2 } } <v10>: * COPY
|
|
=====================
|
|
== t8 ==
|
|
fun t8(a : Int) {
|
|
l@ for (i in 1..a) {
|
|
try {
|
|
1
|
|
if (2 > 3) {
|
|
continue@l
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
}
|
|
---------------------
|
|
<v0>: Int NEW: magic[FAKE_INITIALIZER](a : Int) -> <v0>
|
|
<v7>: Int NEW: magic[LOOP_RANGE_ITERATION](1..a|<v6>) -> <v7>
|
|
1 <v1>: Int NEW: r(1) -> <v1>
|
|
a <v2>: Int NEW: r(a) -> <v2>
|
|
1..a <v6>: {<: Iterable<Int>} NEW: call(1..a, next) -> <v6>
|
|
1 <v8>: * NEW: r(1) -> <v8>
|
|
2 <v9>: {<: Comparable<Int>} NEW: r(2) -> <v9>
|
|
3 <v10>: Int NEW: r(3) -> <v10>
|
|
2 > 3 <v11>: Boolean NEW: call(2 > 3, compareTo|<v9>, <v10>) -> <v11>
|
|
continue@l !<v13>: *
|
|
{ continue@l } !<v13>: * COPY
|
|
if (2 > 3) { continue@l } <v14>: * NEW: merge(if (2 > 3) { continue@l }|!<v13>) -> <v14>
|
|
{ 1 if (2 > 3) { continue@l } } <v14>: * COPY
|
|
2 <v12>: * NEW: r(2) -> <v12>
|
|
{ 2 } <v12>: * COPY
|
|
try { 1 if (2 > 3) { continue@l } } finally { 2 } <v15>: * NEW: merge(try { 1 if (2 > 3) { continue@l } } finally { 2 }|<v14>) -> <v15>
|
|
{ try { 1 if (2 > 3) { continue@l } } finally { 2 } } <v15>: * COPY
|
|
for (i in 1..a) { try { 1 if (2 > 3) { continue@l } } finally { 2 } } !<v16>: *
|
|
l@ for (i in 1..a) { try { 1 if (2 > 3) { continue@l } } finally { 2 } } !<v16>: * COPY
|
|
{ l@ for (i in 1..a) { try { 1 if (2 > 3) { continue@l } } finally { 2 } } } !<v16>: * COPY
|
|
=====================
|
|
== t9 ==
|
|
fun t9(a : Int) {
|
|
try {
|
|
l@ for (i in 1..a) {
|
|
1
|
|
if (2 > 3) {
|
|
continue@l
|
|
}
|
|
}
|
|
5
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
<v0>: Int NEW: magic[FAKE_INITIALIZER](a : Int) -> <v0>
|
|
<v7>: Int NEW: magic[LOOP_RANGE_ITERATION](1..a|<v6>) -> <v7>
|
|
1 <v1>: Int NEW: r(1) -> <v1>
|
|
a <v2>: Int NEW: r(a) -> <v2>
|
|
1..a <v6>: {<: Iterable<Int>} NEW: call(1..a, next) -> <v6>
|
|
1 <v8>: * NEW: r(1) -> <v8>
|
|
2 <v9>: {<: Comparable<Int>} NEW: r(2) -> <v9>
|
|
3 <v10>: Int NEW: r(3) -> <v10>
|
|
2 > 3 <v11>: Boolean NEW: call(2 > 3, compareTo|<v9>, <v10>) -> <v11>
|
|
continue@l !<v12>: *
|
|
{ continue@l } !<v12>: * COPY
|
|
if (2 > 3) { continue@l } <v13>: * NEW: merge(if (2 > 3) { continue@l }|!<v12>) -> <v13>
|
|
{ 1 if (2 > 3) { continue@l } } <v13>: * COPY
|
|
for (i in 1..a) { 1 if (2 > 3) { continue@l } } !<v14>: *
|
|
l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } !<v14>: * COPY
|
|
5 <v15>: * NEW: r(5) -> <v15>
|
|
{ l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } 5 } <v15>: * COPY
|
|
2 <v16>: * NEW: r(2) -> <v16>
|
|
{ 2 } <v16>: * COPY
|
|
try { l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } 5 } finally { 2 } <v17>: * NEW: merge(try { l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } 5 } finally { 2 }|<v15>) -> <v17>
|
|
{ try { l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } 5 } finally { 2 } } <v17>: * COPY
|
|
=====================
|
|
== t10 ==
|
|
fun t10(a : Int) {
|
|
try {
|
|
l@ for (i in 1..a) {
|
|
1
|
|
if (2 > 3) {
|
|
continue@l
|
|
}
|
|
}
|
|
} finally {
|
|
2
|
|
}
|
|
}
|
|
---------------------
|
|
<v0>: Int NEW: magic[FAKE_INITIALIZER](a : Int) -> <v0>
|
|
<v7>: Int NEW: magic[LOOP_RANGE_ITERATION](1..a|<v6>) -> <v7>
|
|
1 <v1>: Int NEW: r(1) -> <v1>
|
|
a <v2>: Int NEW: r(a) -> <v2>
|
|
1..a <v6>: {<: Iterable<Int>} NEW: call(1..a, next) -> <v6>
|
|
1 <v8>: * NEW: r(1) -> <v8>
|
|
2 <v9>: {<: Comparable<Int>} NEW: r(2) -> <v9>
|
|
3 <v10>: Int NEW: r(3) -> <v10>
|
|
2 > 3 <v11>: Boolean NEW: call(2 > 3, compareTo|<v9>, <v10>) -> <v11>
|
|
continue@l !<v12>: *
|
|
{ continue@l } !<v12>: * COPY
|
|
if (2 > 3) { continue@l } <v13>: * NEW: merge(if (2 > 3) { continue@l }|!<v12>) -> <v13>
|
|
{ 1 if (2 > 3) { continue@l } } <v13>: * COPY
|
|
for (i in 1..a) { 1 if (2 > 3) { continue@l } } !<v14>: *
|
|
l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } !<v14>: * COPY
|
|
{ l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } } !<v14>: * COPY
|
|
2 <v15>: * NEW: r(2) -> <v15>
|
|
{ 2 } <v15>: * COPY
|
|
try { l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } } finally { 2 } <v16>: * NEW: merge(try { l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } } finally { 2 }|!<v14>) -> <v16>
|
|
{ try { l@ for (i in 1..a) { 1 if (2 > 3) { continue@l } } } finally { 2 } } <v16>: * COPY
|
|
=====================
|
|
== t11 ==
|
|
fun t11() {
|
|
try {
|
|
return 1
|
|
}
|
|
finally {
|
|
return 2
|
|
}
|
|
}
|
|
---------------------
|
|
1 <v0>: Unit NEW: r(1) -> <v0>
|
|
return 1 !<v3>: *
|
|
{ return 1 } !<v3>: * COPY
|
|
2 <v1>: Unit NEW: r(2) -> <v1>
|
|
return 2 !<v2>: *
|
|
{ return 2 } !<v2>: * COPY
|
|
try { return 1 } finally { return 2 } <v4>: * NEW: merge(try { return 1 } finally { return 2 }|!<v3>) -> <v4>
|
|
{ try { return 1 } finally { return 2 } } <v4>: * COPY
|
|
=====================
|
|
== t12 ==
|
|
fun t12() : Int {
|
|
try {
|
|
return 1
|
|
}
|
|
finally {
|
|
doSmth(3)
|
|
}
|
|
}
|
|
---------------------
|
|
1 <v0>: Int NEW: r(1) -> <v0>
|
|
return 1 !<v3>: *
|
|
{ return 1 } !<v3>: * COPY
|
|
3 <v1>: Int NEW: r(3) -> <v1>
|
|
doSmth(3) <v2>: * NEW: call(doSmth(3), doSmth|<v1>) -> <v2>
|
|
{ doSmth(3) } <v2>: * COPY
|
|
try { return 1 } finally { doSmth(3) } <v4>: * NEW: merge(try { return 1 } finally { doSmth(3) }|!<v3>) -> <v4>
|
|
{ try { return 1 } finally { doSmth(3) } } <v4>: * COPY
|
|
=====================
|
|
== t13 ==
|
|
fun t13() : Int {
|
|
try {
|
|
return 1
|
|
}
|
|
catch (e: UnsupportedOperationException) {
|
|
doSmth(2)
|
|
}
|
|
finally {
|
|
doSmth(3)
|
|
}
|
|
}
|
|
---------------------
|
|
<v4>: {<: UnsupportedOperationException /* = UnsupportedOperationException */} NEW: magic[FAKE_INITIALIZER](e: UnsupportedOperationException) -> <v4>
|
|
1 <v0>: Int NEW: r(1) -> <v0>
|
|
return 1 !<v3>: *
|
|
{ return 1 } !<v3>: * COPY
|
|
2 <v5>: Int NEW: r(2) -> <v5>
|
|
doSmth(2) <v6>: * NEW: call(doSmth(2), doSmth|<v5>) -> <v6>
|
|
{ doSmth(2) } <v6>: * COPY
|
|
3 <v1>: Int NEW: r(3) -> <v1>
|
|
doSmth(3) <v2>: * NEW: call(doSmth(3), doSmth|<v1>) -> <v2>
|
|
{ doSmth(3) } <v2>: * COPY
|
|
try { return 1 } catch (e: UnsupportedOperationException) { doSmth(2) } finally { doSmth(3) } <v7>: * NEW: merge(try { return 1 } catch (e: UnsupportedOperationException) { doSmth(2) } finally { doSmth(3) }|!<v3>, <v6>) -> <v7>
|
|
{ try { return 1 } catch (e: UnsupportedOperationException) { doSmth(2) } finally { doSmth(3) } } <v7>: * COPY
|
|
=====================
|
|
== t14 ==
|
|
fun t14() : Int {
|
|
try {
|
|
return 1
|
|
}
|
|
catch (e: UnsupportedOperationException) {
|
|
doSmth(2)
|
|
}
|
|
}
|
|
---------------------
|
|
<v2>: {<: UnsupportedOperationException /* = UnsupportedOperationException */} NEW: magic[FAKE_INITIALIZER](e: UnsupportedOperationException) -> <v2>
|
|
1 <v0>: Int NEW: r(1) -> <v0>
|
|
return 1 !<v1>: *
|
|
{ return 1 } !<v1>: * COPY
|
|
2 <v3>: Int NEW: r(2) -> <v3>
|
|
doSmth(2) <v4>: * NEW: call(doSmth(2), doSmth|<v3>) -> <v4>
|
|
{ doSmth(2) } <v4>: * COPY
|
|
try { return 1 } catch (e: UnsupportedOperationException) { doSmth(2) } <v5>: * NEW: merge(try { return 1 } catch (e: UnsupportedOperationException) { doSmth(2) }|!<v1>, <v4>) -> <v5>
|
|
{ try { return 1 } catch (e: UnsupportedOperationException) { doSmth(2) } } <v5>: * COPY
|
|
=====================
|
|
== t15 ==
|
|
fun t15() : Int {
|
|
try {
|
|
return 1
|
|
}
|
|
catch (e: UnsupportedOperationException) {
|
|
return 2
|
|
}
|
|
finally {
|
|
doSmth(3)
|
|
}
|
|
}
|
|
---------------------
|
|
<v4>: {<: UnsupportedOperationException /* = UnsupportedOperationException */} NEW: magic[FAKE_INITIALIZER](e: UnsupportedOperationException) -> <v4>
|
|
1 <v0>: Int NEW: r(1) -> <v0>
|
|
return 1 !<v3>: *
|
|
{ return 1 } !<v3>: * COPY
|
|
2 <v5>: Int NEW: r(2) -> <v5>
|
|
return 2 !<v6>: *
|
|
{ return 2 } !<v6>: * COPY
|
|
3 <v1>: Int NEW: r(3) -> <v1>
|
|
doSmth(3) <v2>: * NEW: call(doSmth(3), doSmth|<v1>) -> <v2>
|
|
{ doSmth(3) } <v2>: * COPY
|
|
try { return 1 } catch (e: UnsupportedOperationException) { return 2 } finally { doSmth(3) } <v7>: * NEW: merge(try { return 1 } catch (e: UnsupportedOperationException) { return 2 } finally { doSmth(3) }|!<v3>, !<v6>) -> <v7>
|
|
{ try { return 1 } catch (e: UnsupportedOperationException) { return 2 } finally { doSmth(3) } } <v7>: * COPY
|
|
=====================
|
|
== t16 ==
|
|
fun t16() : Int {
|
|
try {
|
|
doSmth(1)
|
|
}
|
|
catch (e: UnsupportedOperationException) {
|
|
return 2
|
|
}
|
|
finally {
|
|
doSmth(3)
|
|
}
|
|
}
|
|
---------------------
|
|
<v2>: {<: UnsupportedOperationException /* = UnsupportedOperationException */} NEW: magic[FAKE_INITIALIZER](e: UnsupportedOperationException) -> <v2>
|
|
1 <v0>: Int NEW: r(1) -> <v0>
|
|
doSmth(1) <v1>: * NEW: call(doSmth(1), doSmth|<v0>) -> <v1>
|
|
{ doSmth(1) } <v1>: * COPY
|
|
2 <v3>: Int NEW: r(2) -> <v3>
|
|
return 2 !<v6>: *
|
|
{ return 2 } !<v6>: * COPY
|
|
3 <v4>: Int NEW: r(3) -> <v4>
|
|
doSmth(3) <v5>: * NEW: call(doSmth(3), doSmth|<v4>) -> <v5>
|
|
{ doSmth(3) } <v5>: * COPY
|
|
try { doSmth(1) } catch (e: UnsupportedOperationException) { return 2 } finally { doSmth(3) } <v7>: * NEW: merge(try { doSmth(1) } catch (e: UnsupportedOperationException) { return 2 } finally { doSmth(3) }|<v1>, !<v6>) -> <v7>
|
|
{ try { doSmth(1) } catch (e: UnsupportedOperationException) { return 2 } finally { doSmth(3) } } <v7>: * COPY
|
|
=====================
|
|
== doSmth ==
|
|
fun doSmth(i: Int) {
|
|
}
|
|
---------------------
|
|
<v0>: Int NEW: magic[FAKE_INITIALIZER](i: Int) -> <v0>
|
|
=====================
|