All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jetbrains.kotlin.resolve.multiplatform.ExpectActualCompatibility.kt Maven / Gradle / Ivy

The newest version!
/*
 * 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.resolve.multiplatform

import org.jetbrains.kotlin.resolve.multiplatform.ExpectActualMatchingCompatibility.Mismatch

private const val TYPE_PARAMETER_COUNT = "number of type parameters is different"
private const val TYPE_PARAMETER_UPPER_BOUNDS = "upper bounds of type parameters are different"

// Note that the reason is used in the diagnostic output, see PlatformIncompatibilityDiagnosticRenderer
/**
 * DON'T USE THIS CLASS. This class is currently used only in diagnostics. Eventually, it will go away KT-62631
 */
sealed interface ExpectActualCompatibility {
    /**
     * DON'T USE THIS CLASS. This class is currently used only in diagnostics. Eventually, it will go away KT-62631
     */
    sealed interface MismatchOrIncompatible : ExpectActualCompatibility {
        val reason: String?
    }
}

/**
 * All mismatches that can be fixed by introducing an overload without this mismatch.
 * In other words: "overloadable" mismatches
 *
 * @see ExpectActualCheckingCompatibility
 */
sealed class ExpectActualMatchingCompatibility : ExpectActualCompatibility {
    sealed class Mismatch(override val reason: String?) : ExpectActualMatchingCompatibility(),
        ExpectActualCompatibility.MismatchOrIncompatible

    object CallableKind : Mismatch("callable kinds are different (function vs property)")
    object ActualJavaField : Mismatch("actualization to Java field is prohibited")
    object ParameterShape : Mismatch("parameter shapes are different (extension vs non-extension)")
    object ParameterCount : Mismatch("number of value parameters is different")
    object FunctionTypeParameterCount : Mismatch(TYPE_PARAMETER_COUNT)
    object ParameterTypes : Mismatch("parameter types are different")
    object FunctionTypeParameterUpperBounds : Mismatch(TYPE_PARAMETER_UPPER_BOUNDS)
    object MatchedSuccessfully : ExpectActualMatchingCompatibility()
}

/**
 * "Non-overloadable" compatibilities
 *
 * @see ExpectActualMatchingCompatibility
 */
sealed class ExpectActualCheckingCompatibility : ExpectActualCompatibility {
    sealed class Incompatible(override val reason: String?) : ExpectActualCheckingCompatibility(),
        ExpectActualCompatibility.MismatchOrIncompatible

    object ClassTypeParameterCount : Incompatible(TYPE_PARAMETER_COUNT)

    // Callables
    object ReturnType : Incompatible("return type is different")
    object ParameterNames : Incompatible("parameter names are different")
    object TypeParameterNames : Incompatible("names of type parameters are different")
    object ValueParameterVararg : Incompatible("some value parameter is vararg in one declaration and non-vararg in the other")
    object ValueParameterNoinline :
        Incompatible("some value parameter is noinline in one declaration and not noinline in the other")
    object ValueParameterCrossinline :
        Incompatible("some value parameter is crossinline in one declaration and not crossinline in the other")

    // Functions
    object FunctionModifiersDifferent : Incompatible("modifiers are different (suspend)")
    object FunctionModifiersNotSubset :
        Incompatible("some modifiers on expected declaration are missing on the actual one (infix, inline, operator)")
    object ActualFunctionWithDefaultParameters :
        Incompatible("actual function cannot have default argument values, they should be declared in the expected function")
    object DefaultArgumentsInExpectActualizedByFakeOverride :
        Incompatible("default argument values inside expect declaration are not allowed for methods actualized via fake override")

    // Properties
    object PropertyKind : Incompatible("property kinds are different (val vs var)")
    object PropertyLateinitModifier : Incompatible("modifiers are different (lateinit)")
    object PropertyConstModifier : Incompatible("modifiers are different (const)")
    class PropertySetterVisibility(
        expectVisibility: org.jetbrains.kotlin.descriptors.Visibility?,
        actualVisibility: org.jetbrains.kotlin.descriptors.Visibility?,
    ) : Incompatible(
        "setter visibility is different. " +
                "Expect declaration setter visibility is '${expectVisibility?.name}'. " +
                "Actual declaration setter visibility is '${actualVisibility?.name}'"
    )

    // Classifiers
    object ClassKind : Incompatible("class kinds are different (class, interface, object, enum, annotation)")
    object ClassModifiers : Incompatible("modifiers are different (companion, inner, inline, value)")
    object FunInterfaceModifier : Incompatible("actual declaration for fun expect interface is not a functional interface")
    object Supertypes : Incompatible("some supertypes are missing in the actual declaration")
    class ClassScopes(
        val mismatchedMembers: List>>>,
        val incompatibleMembers: List, /* actuals */ Collection>>>,
    ) : Incompatible("some expected members have no actual ones")
    object EnumEntries : Incompatible("some entries from expected enum are missing in the actual enum")
    object IllegalRequiresOpt : Incompatible("opt-in annotations are prohibited to be 'expect' or 'actual'. Instead, declare annotation once in common sources.")

    // Common
    class Modality(
        expectModality: org.jetbrains.kotlin.descriptors.Modality?,
        actualModality: org.jetbrains.kotlin.descriptors.Modality?,
    ) : Incompatible(
        "modality is different. " +
                "Expect declaration modality is '${expectModality.toString().lowercase()}'. " +
                "Actual declaration modality is '${actualModality.toString().lowercase()}'"
    )
    class Visibility(
        expectVisibility: org.jetbrains.kotlin.descriptors.Visibility,
        actualVisibility: org.jetbrains.kotlin.descriptors.Visibility,
    ) : Incompatible(
        "visibility is different. " +
                "Expect declaration visibility is '${expectVisibility.name}'. " +
                "Actual declaration visibility is '${actualVisibility.name}'"
    )

    object ClassTypeParameterUpperBounds : Incompatible(TYPE_PARAMETER_UPPER_BOUNDS)
    object TypeParameterVariance : Incompatible("declaration-site variances of type parameters are different")
    object TypeParameterReified : Incompatible("some type parameter is reified in one declaration and non-reified in the other")
    object Compatible : ExpectActualCheckingCompatibility()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy