org.jetbrains.kotlin.fir.plugin.FunctionBuildingContext.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-2022 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.plugin
import org.jetbrains.kotlin.GeneratedDeclarationKey
import org.jetbrains.kotlin.fir.FirSession
import org.jetbrains.kotlin.fir.declarations.*
import org.jetbrains.kotlin.fir.declarations.builder.buildValueParameter
import org.jetbrains.kotlin.fir.expressions.builder.buildExpressionStub
import org.jetbrains.kotlin.fir.moduleData
import org.jetbrains.kotlin.fir.symbols.impl.FirClassSymbol
import org.jetbrains.kotlin.fir.symbols.impl.FirFunctionSymbol
import org.jetbrains.kotlin.fir.symbols.impl.FirValueParameterSymbol
import org.jetbrains.kotlin.fir.types.ConeKotlinType
import org.jetbrains.kotlin.fir.toFirResolvedTypeRef
import org.jetbrains.kotlin.name.CallableId
import org.jetbrains.kotlin.name.Name
public sealed class FunctionBuildingContext(
protected val callableId: CallableId,
session: FirSession,
key: GeneratedDeclarationKey,
owner: FirClassSymbol<*>?
) : DeclarationBuildingContext(session, key, owner) {
protected data class ValueParameterData(
val name: Name,
val typeProvider: (List) -> ConeKotlinType,
val isCrossinline: Boolean,
val isNoinline: Boolean,
val isVararg: Boolean,
val hasDefaultValue: Boolean,
val key: GeneratedDeclarationKey
)
protected val valueParameters: MutableList = mutableListOf()
/**
* Adds value parameter with [type] type to constructed function
*
* If you set [hasDefaultValue] to true then you need to generate actual default value
* in [IrGenerationExtension]
*/
public fun valueParameter(
name: Name,
type: ConeKotlinType,
isCrossinline: Boolean = false,
isNoinline: Boolean = false,
isVararg: Boolean = false,
hasDefaultValue: Boolean = false,
key: GeneratedDeclarationKey = [email protected]
) {
valueParameter(name, { type }, isCrossinline, isNoinline, isVararg, hasDefaultValue, key)
}
/**
* Adds value parameter with type provided by [typeProvider] to constructed function
* Use this overload when parameter type uses type parameters of constructed declaration
*
* If you set [hasDefaultValue] to true then you need to generate actual default value
* in [IrGenerationExtension]
*/
public fun valueParameter(
name: Name,
typeProvider: (List) -> ConeKotlinType,
isCrossinline: Boolean = false,
isNoinline: Boolean = false,
isVararg: Boolean = false,
hasDefaultValue: Boolean = false,
key: GeneratedDeclarationKey = [email protected]
) {
valueParameters += ValueParameterData(name, typeProvider, isCrossinline, isNoinline, isVararg, hasDefaultValue, key)
}
protected fun generateValueParameter(
valueParameter: ValueParameterData,
containingFunctionSymbol: FirFunctionSymbol<*>,
functionTypeParameters: List
): FirValueParameter {
return buildValueParameter {
resolvePhase = FirResolvePhase.BODY_RESOLVE
moduleData = session.moduleData
origin = valueParameter.key.origin
returnTypeRef = valueParameter.typeProvider.invoke(functionTypeParameters).toFirResolvedTypeRef()
name = valueParameter.name
symbol = FirValueParameterSymbol(name)
if (valueParameter.hasDefaultValue) {
// TODO: check how it will actually work in fir2ir
defaultValue = buildExpressionStub { coneTypeOrNull = session.builtinTypes.nothingType.coneType }
}
this.containingFunctionSymbol = containingFunctionSymbol
isCrossinline = valueParameter.isCrossinline
isNoinline = valueParameter.isNoinline
isVararg = valueParameter.isVararg
}
}
}