org.jetbrains.kotlin.fir.expressions.impl.FirCallableReferenceAccessImpl.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-2024 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.
*/
// This file was generated automatically. See compiler/fir/tree/tree-generator/Readme.md.
// DO NOT MODIFY IT MANUALLY.
@file:Suppress("DuplicatedCode")
package org.jetbrains.kotlin.fir.expressions.impl
import org.jetbrains.kotlin.KtSourceElement
import org.jetbrains.kotlin.fir.FirImplementationDetail
import org.jetbrains.kotlin.fir.MutableOrEmptyList
import org.jetbrains.kotlin.fir.builder.toMutableOrEmpty
import org.jetbrains.kotlin.fir.diagnostics.ConeDiagnostic
import org.jetbrains.kotlin.fir.expressions.FirAnnotation
import org.jetbrains.kotlin.fir.expressions.FirCallableReferenceAccess
import org.jetbrains.kotlin.fir.expressions.FirExpression
import org.jetbrains.kotlin.fir.expressions.UnresolvedExpressionTypeAccess
import org.jetbrains.kotlin.fir.references.FirNamedReference
import org.jetbrains.kotlin.fir.references.FirReference
import org.jetbrains.kotlin.fir.types.ConeKotlinType
import org.jetbrains.kotlin.fir.types.FirTypeProjection
import org.jetbrains.kotlin.fir.visitors.FirTransformer
import org.jetbrains.kotlin.fir.visitors.FirVisitor
import org.jetbrains.kotlin.fir.visitors.transformInplace
@OptIn(UnresolvedExpressionTypeAccess::class)
internal class FirCallableReferenceAccessImpl(
@property:UnresolvedExpressionTypeAccess
override var coneTypeOrNull: ConeKotlinType?,
override var annotations: MutableOrEmptyList,
override var contextReceiverArguments: MutableOrEmptyList,
override var typeArguments: MutableOrEmptyList,
override var explicitReceiver: FirExpression?,
override var dispatchReceiver: FirExpression?,
override var extensionReceiver: FirExpression?,
override var source: KtSourceElement?,
override var nonFatalDiagnostics: MutableOrEmptyList,
override var calleeReference: FirNamedReference,
override var hasQuestionMarkAtLHS: Boolean,
) : FirCallableReferenceAccess() {
override fun acceptChildren(visitor: FirVisitor, data: D) {
annotations.forEach { it.accept(visitor, data) }
contextReceiverArguments.forEach { it.accept(visitor, data) }
typeArguments.forEach { it.accept(visitor, data) }
explicitReceiver?.accept(visitor, data)
if (dispatchReceiver !== explicitReceiver) {
dispatchReceiver?.accept(visitor, data)
}
if (extensionReceiver !== explicitReceiver && extensionReceiver !== dispatchReceiver) {
extensionReceiver?.accept(visitor, data)
}
calleeReference.accept(visitor, data)
}
override fun transformChildren(transformer: FirTransformer, data: D): FirCallableReferenceAccessImpl {
transformAnnotations(transformer, data)
contextReceiverArguments.transformInplace(transformer, data)
transformTypeArguments(transformer, data)
explicitReceiver = explicitReceiver?.transform(transformer, data)
if (dispatchReceiver !== explicitReceiver) {
dispatchReceiver = dispatchReceiver?.transform(transformer, data)
}
if (extensionReceiver !== explicitReceiver && extensionReceiver !== dispatchReceiver) {
extensionReceiver = extensionReceiver?.transform(transformer, data)
}
transformCalleeReference(transformer, data)
return this
}
override fun transformAnnotations(transformer: FirTransformer, data: D): FirCallableReferenceAccessImpl {
annotations.transformInplace(transformer, data)
return this
}
override fun transformTypeArguments(transformer: FirTransformer, data: D): FirCallableReferenceAccessImpl {
typeArguments.transformInplace(transformer, data)
return this
}
override fun transformExplicitReceiver(transformer: FirTransformer, data: D): FirCallableReferenceAccessImpl {
explicitReceiver = explicitReceiver?.transform(transformer, data)
return this
}
override fun transformCalleeReference(transformer: FirTransformer, data: D): FirCallableReferenceAccessImpl {
calleeReference = calleeReference.transform(transformer, data)
return this
}
override fun replaceConeTypeOrNull(newConeTypeOrNull: ConeKotlinType?) {
coneTypeOrNull = newConeTypeOrNull
}
override fun replaceAnnotations(newAnnotations: List) {
annotations = newAnnotations.toMutableOrEmpty()
}
override fun replaceContextReceiverArguments(newContextReceiverArguments: List) {
contextReceiverArguments = newContextReceiverArguments.toMutableOrEmpty()
}
override fun replaceTypeArguments(newTypeArguments: List) {
typeArguments = newTypeArguments.toMutableOrEmpty()
}
override fun replaceExplicitReceiver(newExplicitReceiver: FirExpression?) {
explicitReceiver = newExplicitReceiver
}
override fun replaceDispatchReceiver(newDispatchReceiver: FirExpression?) {
dispatchReceiver = newDispatchReceiver
}
override fun replaceExtensionReceiver(newExtensionReceiver: FirExpression?) {
extensionReceiver = newExtensionReceiver
}
@FirImplementationDetail
override fun replaceSource(newSource: KtSourceElement?) {
source = newSource
}
override fun replaceNonFatalDiagnostics(newNonFatalDiagnostics: List) {
nonFatalDiagnostics = newNonFatalDiagnostics.toMutableOrEmpty()
}
override fun replaceCalleeReference(newCalleeReference: FirNamedReference) {
calleeReference = newCalleeReference
}
override fun replaceCalleeReference(newCalleeReference: FirReference) {
require(newCalleeReference is FirNamedReference)
replaceCalleeReference(newCalleeReference)
}
override fun replaceHasQuestionMarkAtLHS(newHasQuestionMarkAtLHS: Boolean) {
hasQuestionMarkAtLHS = newHasQuestionMarkAtLHS
}
}