08fb9c2122
When a try-catch expression is passed as an argument to the inline lambda parameter, lambda variable on stack is spilled and restored in several different locations (1 for try-block, 1 for each catch-blocks). So it's possible that lambda to be invoked comes from multiple loads, all of which should have the same "root" lambda parameter.
6 lines
184 B
Kotlin
Vendored
6 lines
184 B
Kotlin
Vendored
fun zap(s: String) = s
|
|
|
|
inline fun tryZap(string: String, fn: (String) -> String) =
|
|
fn(try { zap(string) } catch (e: Exception) { "" })
|
|
|
|
fun box(): String = tryZap("OK") { it } |