5b58eb8491
Most of these tests used this directive as a way to opt in to a new language feature, and most of those features are already stable for a long time, so no opt-in is needed. Some other tests used the directive to opt out from a language feature, replace those by the `LANGUAGE` directive. One test used the directive to test behavior that actually depended on the API version; use `API_VERSION` directive there instead.
36 lines
677 B
Kotlin
Vendored
36 lines
677 B
Kotlin
Vendored
// TARGET_BACKEND: JVM
|
|
// WITH_RUNTIME
|
|
|
|
// FILE: J.java
|
|
|
|
public class J {
|
|
public static void deinitialize(Foo foo) {
|
|
foo.bar = null;
|
|
}
|
|
}
|
|
|
|
// FILE: main.kt
|
|
|
|
class Foo {
|
|
lateinit var bar: String
|
|
|
|
fun test(): String {
|
|
if (this::bar.isInitialized) return "Fail 1"
|
|
J.deinitialize(this)
|
|
if (this::bar.isInitialized) return "Fail 2"
|
|
|
|
bar = "A"
|
|
if (!this::bar.isInitialized) return "Fail 3"
|
|
J.deinitialize(this)
|
|
if (this::bar.isInitialized) return "Fail 4"
|
|
|
|
bar = "OK"
|
|
if (!this::bar.isInitialized) return "Fail 5"
|
|
return bar
|
|
}
|
|
}
|
|
|
|
fun box(): String {
|
|
return Foo().test()
|
|
}
|