org.jetbrains.kotlin.fir.java.declarations.FirJavaValueParameter.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlin-compiler-embeddable Show documentation
Show all versions of kotlin-compiler-embeddable Show documentation
the Kotlin compiler embeddable
/*
* Copyright 2010-2023 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
package org.jetbrains.kotlin.fir.java.declarations
import org.jetbrains.kotlin.KtSourceElement
import org.jetbrains.kotlin.fir.FirImplementationDetail
import org.jetbrains.kotlin.fir.FirModuleData
import org.jetbrains.kotlin.fir.builder.FirBuilderDsl
import org.jetbrains.kotlin.fir.declarations.*
import org.jetbrains.kotlin.fir.declarations.impl.FirResolvedDeclarationStatusImpl
import org.jetbrains.kotlin.fir.expressions.FirAnnotation
import org.jetbrains.kotlin.fir.expressions.FirExpression
import org.jetbrains.kotlin.fir.references.FirControlFlowGraphReference
import org.jetbrains.kotlin.fir.symbols.impl.FirFunctionSymbol
import org.jetbrains.kotlin.fir.symbols.impl.FirValueParameterSymbol
import org.jetbrains.kotlin.fir.types.ConeSimpleKotlinType
import org.jetbrains.kotlin.fir.types.FirTypeRef
import org.jetbrains.kotlin.fir.visitors.FirTransformer
import org.jetbrains.kotlin.fir.visitors.FirVisitor
import org.jetbrains.kotlin.fir.visitors.transformSingle
import org.jetbrains.kotlin.name.Name
import org.jetbrains.kotlin.serialization.deserialization.descriptors.DeserializedContainerSource
import kotlin.contracts.ExperimentalContracts
import kotlin.contracts.InvocationKind
import kotlin.contracts.contract
import kotlin.properties.Delegates
@OptIn(FirImplementationDetail::class)
class FirJavaValueParameter @FirImplementationDetail constructor(
override val source: KtSourceElement?,
override val moduleData: FirModuleData,
override val origin: FirDeclarationOrigin.Java,
resolvePhase: FirResolvePhase,
override val attributes: FirDeclarationAttributes,
override var returnTypeRef: FirTypeRef,
override val name: Name,
override val symbol: FirValueParameterSymbol,
annotationBuilder: () -> List,
var lazyDefaultValue: Lazy?,
override val containingFunctionSymbol: FirFunctionSymbol<*>,
override val isVararg: Boolean,
) : FirValueParameter() {
override var defaultValue: FirExpression?
get() = lazyDefaultValue?.value
set(value) {
lazyDefaultValue = value?.let(::lazyOf)
}
init {
symbol.bind(this)
@OptIn(ResolveStateAccess::class)
this.resolveState = resolvePhase.asResolveState()
}
override val isCrossinline: Boolean
get() = false
override val isNoinline: Boolean
get() = false
override val isVal: Boolean
get() = true
override val isVar: Boolean
get() = false
override val annotations: List by lazy { annotationBuilder() }
override val receiverParameter: FirReceiverParameter?
get() = null
override val deprecationsProvider: DeprecationsProvider
get() = EmptyDeprecationsProvider
override val initializer: FirExpression?
get() = null
override val delegate: FirExpression?
get() = null
override val getter: FirPropertyAccessor?
get() = null
override val setter: FirPropertyAccessor?
get() = null
override val backingField: FirBackingField?
get() = null
override val controlFlowGraphReference: FirControlFlowGraphReference?
get() = null
override val typeParameters: List
get() = emptyList()
override val status: FirDeclarationStatus
get() = FirResolvedDeclarationStatusImpl.DEFAULT_STATUS_FOR_STATUSLESS_DECLARATIONS
override val containerSource: DeserializedContainerSource?
get() = null
override val dispatchReceiverType: ConeSimpleKotlinType?
get() = null
override val contextReceivers: List
get() = emptyList()
override fun acceptChildren(visitor: FirVisitor, data: D) {
returnTypeRef.accept(visitor, data)
annotations.forEach { it.accept(visitor, data) }
defaultValue?.accept(visitor, data)
}
override fun transformChildren(transformer: FirTransformer, data: D): FirValueParameter {
transformReturnTypeRef(transformer, data)
transformOtherChildren(transformer, data)
return this
}
override fun transformReturnTypeRef(transformer: FirTransformer, data: D): FirValueParameter {
returnTypeRef = returnTypeRef.transformSingle(transformer, data)
return this
}
override fun transformReceiverParameter(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformInitializer(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformDelegate(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformGetter(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformSetter(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformBackingField(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun replaceAnnotations(newAnnotations: List) {
throw AssertionError("Mutating annotations for FirJava* is not supported")
}
override fun transformAnnotations(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformOtherChildren(transformer: FirTransformer, data: D): FirValueParameter {
defaultValue = defaultValue?.transformSingle(transformer, data)
return this
}
override fun transformTypeParameters(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun transformStatus(transformer: FirTransformer, data: D): FirValueParameter {
return this
}
override fun replaceReturnTypeRef(newReturnTypeRef: FirTypeRef) {
returnTypeRef = newReturnTypeRef
}
override fun replaceReceiverParameter(newReceiverParameter: FirReceiverParameter?) {}
override fun replaceDeprecationsProvider(newDeprecationsProvider: DeprecationsProvider) {
}
override fun replaceInitializer(newInitializer: FirExpression?) {
}
override fun replaceDelegate(newDelegate: FirExpression?) {}
override fun replaceControlFlowGraphReference(newControlFlowGraphReference: FirControlFlowGraphReference?) {
}
override fun replaceDefaultValue(newDefaultValue: FirExpression?) {
error("Java value parameter cannot has default value")
}
override fun replaceGetter(newGetter: FirPropertyAccessor?) {
}
override fun replaceSetter(newSetter: FirPropertyAccessor?) {
}
override fun replaceContextReceivers(newContextReceivers: List) {
error("Body cannot be replaced for FirJavaValueParameter")
}
override fun replaceStatus(newStatus: FirDeclarationStatus) {
error("Status cannot be replaced for FirJavaValueParameter")
}
}
@FirBuilderDsl
class FirJavaValueParameterBuilder {
var source: KtSourceElement? = null
lateinit var moduleData: FirModuleData
var attributes: FirDeclarationAttributes = FirDeclarationAttributes()
lateinit var returnTypeRef: FirTypeRef
lateinit var name: Name
lateinit var annotationBuilder: () -> List
var defaultValue: Lazy? = null
lateinit var containingFunctionSymbol: FirFunctionSymbol<*>
var isVararg: Boolean by Delegates.notNull()
var isFromSource: Boolean by Delegates.notNull()
@OptIn(FirImplementationDetail::class)
fun build(): FirJavaValueParameter {
return FirJavaValueParameter(
source,
moduleData,
origin = javaOrigin(isFromSource),
resolvePhase = FirResolvePhase.ANALYZED_DEPENDENCIES,
attributes,
returnTypeRef,
name,
symbol = FirValueParameterSymbol(name),
annotationBuilder,
defaultValue,
containingFunctionSymbol,
isVararg,
)
}
}
inline fun buildJavaValueParameter(init: FirJavaValueParameterBuilder.() -> Unit): FirJavaValueParameter {
return FirJavaValueParameterBuilder().apply(init).build()
}
@OptIn(ExperimentalContracts::class)
inline fun buildJavaValueParameterCopy(original: FirValueParameter, init: FirJavaValueParameterBuilder.() -> Unit): FirValueParameter {
contract {
callsInPlace(init, InvocationKind.EXACTLY_ONCE)
}
val copyBuilder = FirJavaValueParameterBuilder()
copyBuilder.source = original.source
copyBuilder.moduleData = original.moduleData
copyBuilder.attributes = original.attributes.copy()
copyBuilder.isFromSource = original.origin.fromSource
copyBuilder.returnTypeRef = original.returnTypeRef
copyBuilder.name = original.name
val annotations = original.annotations
copyBuilder.annotationBuilder = { annotations }
copyBuilder.defaultValue = if (original is FirJavaValueParameter) original.lazyDefaultValue else original.defaultValue?.let(::lazyOf)
copyBuilder.containingFunctionSymbol = original.containingFunctionSymbol
copyBuilder.isVararg = original.isVararg
return copyBuilder.apply(init).build()
}