org.jetbrains.kotlin.ir.interpreter.proxy.reflection.KClassProxy.kt Maven / Gradle / Ivy
/*
* Copyright 2010-2020 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.ir.interpreter.proxy.reflection
import org.jetbrains.kotlin.descriptors.Modality
import org.jetbrains.kotlin.ir.interpreter.CallInterceptor
import org.jetbrains.kotlin.ir.interpreter.exceptions.verify
import org.jetbrains.kotlin.ir.interpreter.internalName
import org.jetbrains.kotlin.ir.interpreter.proxy.Proxy
import org.jetbrains.kotlin.ir.interpreter.state.State
import org.jetbrains.kotlin.ir.interpreter.state.isSubtypeOf
import org.jetbrains.kotlin.ir.interpreter.state.reflection.KClassState
import org.jetbrains.kotlin.ir.util.defaultType
import kotlin.reflect.*
internal class KClassProxy(
override val state: KClassState, override val callInterceptor: CallInterceptor
) : ReflectionProxy, KClass {
override val simpleName: String?
get() = state.classReference.name.takeIf { !it.isSpecial }?.asString()
override val qualifiedName: String?
get() = if (!state.classReference.name.isSpecial) state.classReference.internalName() else null
@Suppress("UNCHECKED_CAST")
override val constructors: Collection>
get() = state.getConstructors(callInterceptor) as Collection>
override val members: Collection>
get() = state.getMembers(callInterceptor)
override val nestedClasses: Collection>
get() = TODO("Not yet implemented")
override val objectInstance: Proxy?
get() = TODO("Not yet implemented")
override val typeParameters: List
get() = state.getTypeParameters(callInterceptor)
override val supertypes: List
get() = state.getSupertypes(callInterceptor)
override val sealedSubclasses: List>
get() = TODO("Not yet implemented")
override val annotations: List
get() = TODO("Not yet implemented")
override val visibility: KVisibility?
get() = state.classReference.visibility.toKVisibility()
override val isFinal: Boolean
get() = state.classReference.modality == Modality.FINAL
override val isOpen: Boolean
get() = state.classReference.modality == Modality.OPEN
override val isAbstract: Boolean
get() = state.classReference.modality == Modality.ABSTRACT
override val isSealed: Boolean
get() = state.classReference.modality == Modality.SEALED
override val isData: Boolean
get() = state.classReference.isData
override val isInner: Boolean
get() = state.classReference.isInner
override val isCompanion: Boolean
get() = state.classReference.isCompanion
override val isFun: Boolean
get() = state.classReference.isFun
override val isValue: Boolean
get() = state.classReference.isValue
override fun isInstance(value: Any?): Boolean {
verify(value is State) { "Cannot interpret `isInstance` method for $value" }
// TODO fix problems with typealias and java classes subtype check
return (value as State).isSubtypeOf(state.classReference.defaultType)
}
override fun equals(other: Any?): Boolean {
if (this === other) return true
if (other !is KClassProxy) return false
return state == other.state
}
override fun hashCode(): Int {
return state.hashCode()
}
override fun toString(): String {
return state.toString()
}
}