org.jetbrains.kotlin.fir.expressions.impl.FirWhenExpressionImpl.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.MutableOrEmptyList
import org.jetbrains.kotlin.fir.builder.toMutableOrEmpty
import org.jetbrains.kotlin.fir.declarations.FirVariable
import org.jetbrains.kotlin.fir.expressions.*
import org.jetbrains.kotlin.fir.references.FirReference
import org.jetbrains.kotlin.fir.types.ConeKotlinType
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 FirWhenExpressionImpl(
override val source: KtSourceElement?,
@property:UnresolvedExpressionTypeAccess
override var coneTypeOrNull: ConeKotlinType?,
override var annotations: MutableOrEmptyList,
override var calleeReference: FirReference,
override var subject: FirExpression?,
override var subjectVariable: FirVariable?,
override val branches: MutableList,
override var exhaustivenessStatus: ExhaustivenessStatus?,
override val usedAsExpression: Boolean,
) : FirWhenExpression() {
override fun acceptChildren(visitor: FirVisitor, data: D) {
annotations.forEach { it.accept(visitor, data) }
calleeReference.accept(visitor, data)
val subjectVariable_ = subjectVariable
if (subjectVariable_ != null) {
subjectVariable_.accept(visitor, data)
} else {
subject?.accept(visitor, data)
}
branches.forEach { it.accept(visitor, data) }
}
override fun transformChildren(transformer: FirTransformer, data: D): FirWhenExpressionImpl {
transformCalleeReference(transformer, data)
transformSubject(transformer, data)
transformBranches(transformer, data)
transformOtherChildren(transformer, data)
return this
}
override fun transformAnnotations(transformer: FirTransformer, data: D): FirWhenExpressionImpl {
annotations.transformInplace(transformer, data)
return this
}
override fun transformCalleeReference(transformer: FirTransformer, data: D): FirWhenExpressionImpl {
calleeReference = calleeReference.transform(transformer, data)
return this
}
override fun transformSubject(transformer: FirTransformer, data: D): FirWhenExpressionImpl {
if (subjectVariable != null) {
subjectVariable = subjectVariable?.transform(transformer, data)
subject = subjectVariable?.initializer
} else {
subject = subject?.transform(transformer, data)
}
return this
}
override fun transformBranches(transformer: FirTransformer, data: D): FirWhenExpressionImpl {
branches.transformInplace(transformer, data)
return this
}
override fun transformOtherChildren(transformer: FirTransformer, data: D): FirWhenExpressionImpl {
transformAnnotations(transformer, data)
return this
}
override fun replaceConeTypeOrNull(newConeTypeOrNull: ConeKotlinType?) {
coneTypeOrNull = newConeTypeOrNull
}
override fun replaceAnnotations(newAnnotations: List) {
annotations = newAnnotations.toMutableOrEmpty()
}
override fun replaceCalleeReference(newCalleeReference: FirReference) {
calleeReference = newCalleeReference
}
override fun replaceExhaustivenessStatus(newExhaustivenessStatus: ExhaustivenessStatus?) {
exhaustivenessStatus = newExhaustivenessStatus
}
}