org.jetbrains.kotlin.fir.symbols.impl.FirClassLikeSymbol.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.symbols.impl
import org.jetbrains.kotlin.descriptors.ClassKind
import org.jetbrains.kotlin.fir.FirSession
import org.jetbrains.kotlin.fir.declarations.*
import org.jetbrains.kotlin.fir.symbols.ConeClassLikeLookupTag
import org.jetbrains.kotlin.fir.symbols.FirBasedSymbol
import org.jetbrains.kotlin.fir.symbols.lazyResolveToPhase
import org.jetbrains.kotlin.fir.types.ConeKotlinType
import org.jetbrains.kotlin.fir.types.FirResolvedTypeRef
import org.jetbrains.kotlin.fir.types.coneType
import org.jetbrains.kotlin.fir.types.toLookupTag
import org.jetbrains.kotlin.mpp.ClassLikeSymbolMarker
import org.jetbrains.kotlin.mpp.RegularClassSymbolMarker
import org.jetbrains.kotlin.mpp.TypeAliasSymbolMarker
import org.jetbrains.kotlin.name.ClassId
import org.jetbrains.kotlin.name.FqName
import org.jetbrains.kotlin.name.SpecialNames
sealed class FirClassLikeSymbol(
val classId: ClassId,
) : FirClassifierSymbol(), ClassLikeSymbolMarker {
abstract override fun toLookupTag(): ConeClassLikeLookupTag
val name get() = classId.shortClassName
fun getOwnDeprecation(session: FirSession): DeprecationsPerUseSite? {
if (annotations.isEmpty() && fir.versionRequirements.isNullOrEmpty()) return null
lazyResolveToPhase(FirResolvePhase.COMPILER_REQUIRED_ANNOTATIONS)
return fir.deprecationsProvider.getDeprecationsInfo(session)
}
val rawStatus: FirDeclarationStatus
get() = fir.status
val resolvedStatus: FirResolvedDeclarationStatus
get() = fir.resolvedStatus()
val typeParameterSymbols: List
get() = fir.typeParameters.map { it.symbol }
val ownTypeParameterSymbols: List
get() = fir.typeParameters.mapNotNull { (it as? FirTypeParameter)?.symbol }
override fun toString(): String = "${this::class.simpleName} ${classId.asString()}"
}
sealed class FirClassSymbol(classId: ClassId) : FirClassLikeSymbol(classId) {
private val lookupTag: ConeClassLikeLookupTag =
if (classId.isLocal) ConeClassLookupTagWithFixedSymbol(classId, this)
else classId.toLookupTag()
override fun toLookupTag(): ConeClassLikeLookupTag = lookupTag
val resolvedSuperTypeRefs: List
get() {
lazyResolveToPhase(FirResolvePhase.SUPER_TYPES)
@Suppress("UNCHECKED_CAST")
return fir.superTypeRefs as List
}
val resolvedSuperTypes: List
get() = resolvedSuperTypeRefs.map { it.coneType }
val declarationSymbols: List>
get() = fir.declarations.map { it.symbol }
val classKind: ClassKind
get() = fir.classKind
}
class FirRegularClassSymbol(classId: ClassId) : FirClassSymbol(classId), RegularClassSymbolMarker {
val companionObjectSymbol: FirRegularClassSymbol?
get() = fir.companionObjectSymbol
val resolvedContextReceivers: List
get() {
if (fir.contextReceivers.isEmpty()) return emptyList()
lazyResolveToPhase(FirResolvePhase.TYPES)
return fir.contextReceivers
}
}
class FirAnonymousObjectSymbol(packageFqName: FqName) : FirClassSymbol(
ClassId(packageFqName, SpecialNames.ANONYMOUS_FQ_NAME, isLocal = true)
)
class FirTypeAliasSymbol(classId: ClassId) : FirClassLikeSymbol(classId), TypeAliasSymbolMarker {
override fun toLookupTag(): ConeClassLikeLookupTag = classId.toLookupTag()
val resolvedExpandedTypeRef: FirResolvedTypeRef
get() {
lazyResolveToPhase(FirResolvePhase.SUPER_TYPES)
return fir.expandedTypeRef as FirResolvedTypeRef
}
}