fc36178f3a
This function was always experimental, as explained in its kdoc, but it was introduced before opt-in requirement markers were supported. Thus, breaking changes (such as in KT-42746) were always expected, and the `@ExperimentalReflectionOnLambdas` annotation just makes it clearer. #KT-45486 Fixed
48 lines
1.2 KiB
Kotlin
Vendored
48 lines
1.2 KiB
Kotlin
Vendored
// !USE_EXPERIMENTAL: kotlin.reflect.jvm.ExperimentalReflectionOnLambdas
|
|
// TARGET_BACKEND: JVM
|
|
// WITH_REFLECT
|
|
|
|
import kotlin.reflect.KParameter
|
|
import kotlin.reflect.jvm.reflect
|
|
import kotlin.test.assertEquals
|
|
import kotlin.test.assertNull
|
|
|
|
fun lambda() {
|
|
val f = { x: Int, y: String? -> }
|
|
|
|
val g = f.reflect()!!
|
|
|
|
// TODO: maybe change this name
|
|
assertEquals("<anonymous>", g.name)
|
|
assertEquals(listOf("x", "y"), g.parameters.map { it.name })
|
|
assertEquals(listOf(false, true), g.parameters.map { it.type.isMarkedNullable })
|
|
}
|
|
|
|
fun funExpr() {
|
|
val f = fun(x: Int, y: String?) {}
|
|
|
|
val g = f.reflect()!!
|
|
|
|
// TODO: maybe change this name
|
|
assertEquals("<no name provided>", g.name)
|
|
assertEquals(listOf("x", "y"), g.parameters.map { it.name })
|
|
assertEquals(listOf(false, true), g.parameters.map { it.type.isMarkedNullable })
|
|
}
|
|
|
|
fun extensionFunExpr() {
|
|
val f = fun String.(): String = this
|
|
|
|
val g = f.reflect()!!
|
|
|
|
assertEquals(KParameter.Kind.EXTENSION_RECEIVER, g.parameters.single().kind)
|
|
assertEquals(null, g.parameters.single().name)
|
|
}
|
|
|
|
fun box(): String {
|
|
lambda()
|
|
funExpr()
|
|
extensionFunExpr()
|
|
|
|
return "OK"
|
|
}
|