org.jetbrains.kotlin.backend.common.extensions.IrGenerationExtension.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-2018 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.backend.common.extensions
import org.jetbrains.kotlin.backend.common.BackendContext
import org.jetbrains.kotlin.extensions.ProjectExtensionDescriptor
import org.jetbrains.kotlin.ir.declarations.IrModuleFragment
import org.jetbrains.kotlin.ir.linkage.IrDeserializer
interface IrGenerationExtension : IrDeserializer.IrLinkerExtension {
companion object :
ProjectExtensionDescriptor(
"org.jetbrains.kotlin.irGenerationExtension", IrGenerationExtension::class.java
)
fun generate(moduleFragment: IrModuleFragment, pluginContext: IrPluginContext)
fun getPlatformIntrinsicExtension(backendContext: BackendContext): IrIntrinsicExtension? = null
// In K1 mode, returns true if this extension should also be applied in the KAPT stub generation mode in Kotlin/JVM. This mode uses
// light analysis in the compiler frontend to produce an "API-only" class file which is then converted to a .java stub. Because of the
// light analysis, the resulting IR does not have function bodies and can contain references to error types. If this method returns
// true, the extension should be ready to handle such incomplete IR. Any modifications to the IR applied during the KAPT stub generation
// mode will only have effect on the .java stub, not the resulting .class files. Compilation to the .class files is done in a separate
// step after stub generation.
//
// IR generation extensions are not applied in K2 KAPT, so this property has no effect when K2 is enabled.
@FirIncompatiblePluginAPI
val shouldAlsoBeAppliedInKaptStubGenerationMode: Boolean get() = false
}
/**
* This interface for common IR is empty because intrinsics are done in a platform-specific way (because of inliner).
* Currently, only JVM intrinsics are supported via JvmIrIntrinsicExtension interface.
*/
interface IrIntrinsicExtension