org.jetbrains.kotlin.fir.scopes.impl.AbstractFirOverrideScope.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-2021 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.scopes.impl
import org.jetbrains.kotlin.fir.FirSession
import org.jetbrains.kotlin.fir.declarations.*
import org.jetbrains.kotlin.fir.scopes.FirOverrideChecker
import org.jetbrains.kotlin.fir.scopes.FirTypeScope
import org.jetbrains.kotlin.fir.symbols.FirBasedSymbol
import org.jetbrains.kotlin.fir.symbols.impl.FirCallableSymbol
import org.jetbrains.kotlin.fir.utils.exceptions.withFirEntry
import org.jetbrains.kotlin.utils.exceptions.errorWithAttachment
abstract class AbstractFirOverrideScope(
val session: FirSession,
protected val overrideChecker: FirOverrideChecker
) : FirTypeScope() {
//base symbol as key, overridden as value
val overrideByBase: MutableMap, FirCallableSymbol<*>?> = mutableMapOf()
// Receiver is super-type function here
protected open fun FirCallableSymbol<*>.getOverridden(overrideCandidates: Set>): FirCallableSymbol<*>? {
val overrideByBaseItem = overrideByBase[this]
if (overrideByBaseItem != null) return overrideByBaseItem
val baseDeclaration = (this as FirBasedSymbol<*>).fir as FirCallableDeclaration
val override = overrideCandidates.firstOrNull {
val overrideCandidate = (it as FirBasedSymbol<*>).fir as FirCallableDeclaration
overrideChecker.similarFunctionsOrBothProperties(
overrideCandidate,
baseDeclaration
)
} // TODO: two or more overrides for one fun?
overrideByBase[this] = override
return override
}
}
internal fun FirOverrideChecker.similarFunctionsOrBothProperties(
overrideCandidate: FirCallableDeclaration,
baseDeclaration: FirCallableDeclaration
): Boolean {
return when {
overrideCandidate.origin == FirDeclarationOrigin.DynamicScope -> false
overrideCandidate is FirSimpleFunction -> when (baseDeclaration) {
is FirSimpleFunction -> isOverriddenFunction(overrideCandidate, baseDeclaration)
is FirProperty -> isOverriddenProperty(overrideCandidate, baseDeclaration)
else -> false
}
overrideCandidate is FirConstructor -> false
overrideCandidate is FirProperty -> baseDeclaration is FirProperty && isOverriddenProperty(overrideCandidate, baseDeclaration)
overrideCandidate is FirField -> baseDeclaration is FirField
else -> errorWithAttachment("Unknown fir callable type") {
withFirEntry("overrideCandidate", overrideCandidate)
withFirEntry("baseDeclaration", baseDeclaration)
}
}
}
fun FirOverrideChecker.similarFunctionsOrBothProperties(
overrideCandidate: FirCallableSymbol<*>,
baseDeclaration: FirCallableSymbol<*>
): Boolean {
return similarFunctionsOrBothProperties(overrideCandidate.fir, baseDeclaration.fir)
}