kotlin.reflect.jvm.internal.impl.descriptors.Visibility.kt Maven / Gradle / Ivy
/*
* Copyright 2010-2015 JetBrains s.r.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package kotlin.reflect.jvm.internal.impl.descriptors
import kotlin.reflect.jvm.internal.impl.resolve.scopes.receivers.ReceiverValue
abstract class Visibility protected constructor(
val name: String,
val isPublicAPI: Boolean
) {
/**
* @param receiver can be used to determine callee accessibility for some special receiver value
*
* 'null'-value basically means that receiver is absent in current call
*
* In case if it's needed to perform basic checks ignoring ones considering receiver (e.g. when checks happen beyond any call),
* special value Visibilities.ALWAYS_SUITABLE_RECEIVER should be used.
* If it's needed to determine whether visibility accepts any receiver, Visibilities.IRRELEVANT_RECEIVER should be used.
*
* NB: Currently Visibilities.IRRELEVANT_RECEIVER has the same effect as 'null'
*
* Also it's important that implementation that take receiver into account do aware about these special values.
*/
abstract fun isVisible(receiver: ReceiverValue?, what: DeclarationDescriptorWithVisibility, from: DeclarationDescriptor): Boolean
/**
* True, if it makes sense to check this visibility in imports and not import inaccessible declarations with such visibility.
* Hint: return true, if this visibility can be checked on file's level.
* Examples:
* it returns false for PROTECTED because protected members of classes can be imported to be used in subclasses of their containers,
* so when we are looking at the import, we don't know whether it is legal somewhere in this file or not.
* it returns true for INTERNAL, because an internal declaration is either visible everywhere in a file, or invisible everywhere in the same file.
* it returns true for PRIVATE, because there's no point in importing privates: they are inaccessible unless their short name is
* already available without an import
*/
abstract fun mustCheckInImports(): Boolean
/**
* @return null if the answer is unknown
*/
protected open fun compareTo(visibility: Visibility): Int? {
return Visibilities.compareLocal(this, visibility)
}
// internal representation for descriptors
open val internalDisplayName: String
get() = name
// external representation for diagnostics
open val externalDisplayName: String
get() = internalDisplayName
@Deprecated(
"Visibility.displayName is deprecated, use internalDisplayName instead",
ReplaceWith("internalDisplayName"),
level = DeprecationLevel.WARNING
)
open val displayName: String
get() = internalDisplayName
override final fun toString() = internalDisplayName
open fun normalize(): Visibility = this
// Should be overloaded in Java visibilities
open fun effectiveVisibility(descriptor: DeclarationDescriptor, checkPublishedApi: Boolean) = effectiveVisibility(normalize(), descriptor, checkPublishedApi)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy