48fb085bf6
#KT-41758 Fixed
84 lines
3.8 KiB
Kotlin
84 lines
3.8 KiB
Kotlin
/*
|
|
* 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 kotlin
|
|
|
|
/**
|
|
* This annotation is present on any class file produced by the Kotlin compiler and is read by the compiler and reflection.
|
|
* Parameters have very short JVM names on purpose: these names appear in all generated class files, and we'd like to reduce their size.
|
|
*/
|
|
@Retention(AnnotationRetention.RUNTIME)
|
|
@Target(AnnotationTarget.CLASS)
|
|
@SinceKotlin("1.3")
|
|
public annotation class Metadata(
|
|
/**
|
|
* A kind of the metadata this annotation encodes. Kotlin compiler recognizes the following kinds (see KotlinClassHeader.Kind):
|
|
*
|
|
* 1 Class
|
|
* 2 File
|
|
* 3 Synthetic class
|
|
* 4 Multi-file class facade
|
|
* 5 Multi-file class part
|
|
*
|
|
* The class file with a kind not listed here is treated as a non-Kotlin file.
|
|
*/
|
|
@get:JvmName("k")
|
|
val kind: Int = 1,
|
|
/**
|
|
* The version of the metadata provided in the arguments of this annotation.
|
|
*/
|
|
@get:JvmName("mv")
|
|
val metadataVersion: IntArray = [],
|
|
/**
|
|
* The version of the bytecode interface (naming conventions, signatures) of the class file annotated with this annotation.
|
|
*/
|
|
@Deprecated(
|
|
"Bytecode version had no significant use in Kotlin metadata and it will be removed in a future version.",
|
|
level = DeprecationLevel.WARNING,
|
|
)
|
|
@get:JvmName("bv")
|
|
val bytecodeVersion: IntArray = [1, 0, 3],
|
|
/**
|
|
* Metadata in a custom format. The format may be different (or even absent) for different kinds.
|
|
*/
|
|
@get:JvmName("d1")
|
|
val data1: Array<String> = [],
|
|
/**
|
|
* An addition to [data1]: array of strings which occur in metadata, written in plain text so that strings already present
|
|
* in the constant pool are reused. These strings may be then indexed in the metadata by an integer index in this array.
|
|
*/
|
|
@get:JvmName("d2")
|
|
val data2: Array<String> = [],
|
|
/**
|
|
* An extra string. For a multi-file part class, internal name of the facade class.
|
|
*/
|
|
@get:JvmName("xs")
|
|
val extraString: String = "",
|
|
/**
|
|
* Fully qualified name of the package this class is located in, from Kotlin's point of view, or empty string if this name
|
|
* does not differ from the JVM's package FQ name. These names can be different in case the [JvmPackageName] annotation is used.
|
|
* Note that this information is also stored in the corresponding module's `.kotlin_module` file.
|
|
*/
|
|
@SinceKotlin("1.2")
|
|
@get:JvmName("pn")
|
|
val packageName: String = "",
|
|
/**
|
|
* An extra int. Bits of this number represent the following flags:
|
|
*
|
|
* * 0 - this is a multi-file class facade or part, compiled with `-Xmultifile-parts-inherit`.
|
|
* * 1 - this class file is compiled by a pre-release version of Kotlin and is not visible to release versions.
|
|
* * 2 - this class file is a compiled Kotlin script source file (.kts).
|
|
* * 3 - "strict metadata version semantics". The metadata of this class file is not supposed to be read by the compiler,
|
|
* whose major.minor version is less than the major.minor version of this metadata ([metadataVersion]).
|
|
* * 4 - this class file is compiled with the new Kotlin compiler backend (JVM IR) introduced in Kotlin 1.4.
|
|
* * 5 - this class file has stable metadata and ABI. This is used only for class files compiled with JVM IR (see flag #4) or FIR (#6),
|
|
* and prevents metadata incompatibility diagnostics from being reported where the class is used.
|
|
* * 6 - this class file is compiled with the new Kotlin compiler frontend (FIR).
|
|
*/
|
|
@SinceKotlin("1.1")
|
|
@get:JvmName("xi")
|
|
val extraInt: Int = 0
|
|
)
|