KProperty1

expect interface KProperty1<T, out V> : KProperty<V> , Function1<T, V> (source)

Represents a property, operations on which take one receiver as a parameter.

actual interface KProperty1<T, out V> : KProperty<V> , Function1<T, V> (source)

Represents a property, operations on which take one receiver as a parameter.

actual interface KProperty1<T, out V> : KProperty<V> , Function1<T, V>

Represents a property, operations on which take one receiver as a parameter.

actual interface KProperty1<T, out V> : KProperty<V> , Function1<T, V>

Parameters

T

the type of the receiver which should be used to obtain the value of the property.

V

the type of the property value.

T

the type of the receiver which should be used to obtain the value of the property.

V

the type of the property value.

T

the type of the receiver which should be used to obtain the value of the property.

V

the type of the property value.

Types

Link copied to clipboard
interface Getter<T, out V> : KProperty.Getter<V> , Function1<T, V>

Getter of the property is a get method declared alongside the property.

Functions

Link copied to clipboard
abstract fun call(vararg args: Any?): V

Calls this callable with the specified list of arguments and returns the result. Throws an exception if the number of specified arguments is not equal to the size of parameters, or if their types do not match the types of the parameters.

Link copied to clipboard
abstract fun callBy(args: Map<KParameter, Any?>): V

Calls this callable with the specified mapping of parameters to arguments and returns the result. If a parameter is not found in the mapping and is not optional (as per KParameter.isOptional), or its type does not match the type of the provided value, an exception is thrown.

Link copied to clipboard
expect abstract fun get(receiver: T): V

Returns the current value of the property.

actual abstract fun get(receiver: T): V

Returns the current value of the property.

actual abstract fun get(receiver: T): V

Returns the current value of the property.

actual abstract fun get(receiver: T): V
Link copied to clipboard
abstract fun getDelegate(receiver: T): Any?

Returns the value of the delegate if this is a delegated property, or null if this property is not delegated. See the Kotlin language documentation for more information.

Since Kotlin 1.1
invoke
Link copied to clipboard
abstract operator fun invoke(p1: T): V
abstract operator fun invoke(p1: T): V
abstract operator fun invoke(p1: T): V
abstract operator override fun invoke(p1: T): V

Properties

Link copied to clipboard
abstract val annotations: List<Annotation>

Annotations which are present on this element.

Link copied to clipboard
abstract override val getter: KProperty1.Getter<T, V>

The getter of this property, used to obtain the value of the property.

Link copied to clipboard
abstract val isAbstract: Boolean

true if this callable is abstract.

Link copied to clipboard
abstract val isConst: Boolean

true if this property is const. See the Kotlin language documentation for more information.

Link copied to clipboard
abstract val isFinal: Boolean

true if this callable is final.

Link copied to clipboard
abstract val isLateinit: Boolean

true if this property is lateinit. See the Kotlin language documentation for more information.

Link copied to clipboard
abstract val isOpen: Boolean

true if this callable is open.

Link copied to clipboard
abstract val isSuspend: Boolean

true if this is a suspending function.

Link copied to clipboard
expect abstract val name: String
actual abstract val name: String

The name of this callable as it was declared in the source code. If the callable has no name, a special invented name is created. Nameless callables include:

actual abstract val name: String

The name of this callable as it was declared in the source code. If the callable has no name, a special invented name is created. Nameless callables include:

actual abstract val name: String

The name of this callable as it was declared in the source code. If the callable has no name, a special invented name is created. Nameless callables include:

Link copied to clipboard
abstract val parameters: List<KParameter>

Parameters required to make a call to this callable. If this callable requires a this instance or an extension receiver parameter, they come first in the list in that order.

Link copied to clipboard
abstract val returnType: KType

The type of values returned by this callable.

abstract val returnType: KType

The type of values returned by this callable.

Link copied to clipboard

The list of type parameters of this callable.

Link copied to clipboard
abstract val visibility: KVisibility?

Visibility of this callable, or null if its visibility cannot be represented in Kotlin.

Inheritors

Link copied to clipboard

Extensions

Link copied to clipboard
suspend fun <R> KCallable<R>.callSuspend(vararg args: Any?): R

Calls a callable in the current suspend context. If the callable is not a suspend function, behaves as KCallable.call. Otherwise, calls the suspend function with current continuation.

Link copied to clipboard
suspend fun <R> KCallable<R>.callSuspendBy(args: Map<KParameter, Any?>): R

Calls a callable in the current suspend context. If the callable is not a suspend function, behaves as KCallable.callBy. Otherwise, calls the suspend function with current continuation.

Link copied to clipboard

Returns a parameter representing the extension receiver instance needed to call this callable, or null if this callable is not an extension.

Link copied to clipboard

Returns an annotation of the given type on this element.

Link copied to clipboard

Returns the parameter of this callable with the given name, or null if there's no such parameter.

Link copied to clipboard

Returns the instance of a delegated extension property, or null if this property is not delegated. Throws an exception if this is not an extension property.

Link copied to clipboard
inline operator fun <T, V> KProperty1<T, V>.getValue(thisRef: T, property: KProperty<*>): V

An extension operator that allows delegating a read-only member or extension property of type V to a property reference to a member or extension property of type V or its subtype.

Link copied to clipboard

Returns true if this element is annotated with an annotation of type T.

Link copied to clipboard

Returns a parameter representing the this instance needed to call this callable, or null if this callable is not a member of a class and thus doesn't take such parameter.

Link copied to clipboard

Provides a way to suppress JVM access checks for a callable.

Link copied to clipboard

Returns a Java Field instance corresponding to the backing field of the given property, or null if the property has no backing field.

Link copied to clipboard

Returns a Java Method instance corresponding to the getter of the given property, or null if the property has no getter, for example in case of a simple private val in a class.

Link copied to clipboard

This is an experimental API. Given a class for a compiled Kotlin lambda or a function expression, returns a KFunction instance providing introspection capabilities for that lambda or function expression and its parameters. Not all features are currently supported, in particular KCallable.call and KCallable.callBy will fail at the moment.

Link copied to clipboard

Returns parameters of this callable, excluding the this instance and the extension receiver parameter.