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

org.jetbrains.kotlin.ir.util.KotlinMangler.kt Maven / Gradle / Ivy

There is a newer version: 2.1.0-Beta1
Show newest version
/*
 * Copyright 2010-2019 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.util

import org.jetbrains.kotlin.descriptors.DeclarationDescriptor
import org.jetbrains.kotlin.ir.declarations.IrDeclaration

interface KotlinMangler {

    val String.hashMangle: Long

    fun D.isExported(compatibleMode: Boolean): Boolean

    /**
     * Returns the mangled name for the declaration [D] to be used for computing that declaration's [IdSignature].
     *
     * Unlike the one computed by [mangleString], this mangled name does not include mangled names of the declaration's parents.
     *
     * For example, for `foo`'s getter in the following code:
     * ```kotlin
     * class Test {
     *     val foo: Int
     * }
     * ```
     * the result of this function will be `"(){}kotlin.Int"` or `"(){}"` (depending on the target platform).
     *
     * **The result of this function affects klib ABI.**
     *
     * @param compatibleMode If `true`, the mangled names of property backing fields are just those fields' names.
     * Otherwise, mangles such fields exactly as their corresponding properties.
     */
    fun D.signatureString(compatibleMode: Boolean): String

    /**
     * Computes the hash code of the string returned by [signatureString] using the CityHash64 algorithm.
     *
     * This hash code is to be used for building the declaration's [IdSignature].
     *
     * **The result of this function affects klib ABI.**
     *
     * @param compatibleMode If `true`, the mangled names of property backing fields are just those fields' names.
     * Otherwise, mangles such fields exactly as their corresponding properties.
     *
     * @see [IdSignature.CommonSignature.id]
     */
    fun D.signatureMangle(compatibleMode: Boolean): Long = signatureString(compatibleMode).hashMangle

    fun D.isPlatformSpecificExport(): Boolean = false

    val manglerName: String

    interface DescriptorMangler : KotlinMangler {
        override val manglerName: String
            get() = "Descriptor"
    }

    interface IrMangler : KotlinMangler {

        /**
         * Returns the mangled name for the declaration, prefixed by mangled names of all its parents.
         *
         * For example, for `foo`'s getter in the following code:
         * ```kotlin
         * class Test {
         *     val foo: Int
         * }
         * ```
         * the result of this function will be `"Test#(){}kotlin.Int"` or `"Test#(){}"`
         * (depending on the target platform).
         *
         * The result of this function is only used for assigning names to binary symbols of Kotlin functions in the final executable
         * produced by Kotlin/Native.
         * **It does not affect klib ABI.**
         *
         * @param compatibleMode If `true`, the mangled names of property backing fields are just those fields' names.
         * Otherwise, mangles such fields exactly as their corresponding properties.
         */
        fun IrDeclaration.mangleString(compatibleMode: Boolean): String

        override val manglerName: String
            get() = "Ir"
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy