Files
kotlin-fork/compiler/testData/codegen/box/reified/arraysReification/jaggedArrayOfNulls.kt
T
Juan Chen 4f6fe1d0ca [FIR]: fix translation of top-level property accesses like array.indices
This commit addresses the following issues:

* accessors didn't take into account their property's receiver type,
which caused NoSuchMethod due to signature mismatch. Now the property's
receiver type is passed to Fir2Ir translation of accessors.

* property's parent was not class, e.g., kotlin.collections.indices.
Now the symbol table collects WrappedPropertyDescriptorWithContainerSource
besides WrappedFunctionDescriptorWithContainerSource, so that
facade classes for such properties can be generated before codegen.

* accessor's parent was not class. Now the containerSource of
the property descriptor is passed to accessor descriptor.
2020-02-25 12:13:42 +03:00

18 lines
515 B
Kotlin
Vendored

// TARGET_BACKEND: JVM
// WITH_RUNTIME
inline fun <reified T> jaggedArrayOfNulls(): Array<Array<T>?> = arrayOfNulls<Array<T>>(1)
fun box(): String {
val x1 = jaggedArrayOfNulls<String>().javaClass.simpleName
if (x1 != "String[][]") return "fail1: $x1"
val x2 = jaggedArrayOfNulls<Array<String>>().javaClass.simpleName
if (x2 != "String[][][]") return "fail2: $x2"
val x3 = jaggedArrayOfNulls<IntArray>().javaClass.simpleName
if (x3 != "int[][][]") return "fail3: $x3"
return "OK"
}