mirror of
https://github.com/jlengrand/kotlin.git
synced 2026-05-17 08:31:29 +00:00
Since we're not yet sure of the design of Experimental/UseExperimental, we're making them "experimental" themselves in some sense, in that the user is required to provide the magic argument "-Xuse-experimental=kotlin.Experimental" to be allowed to use either Experimental or UseExperimental. This is more convenient than the previous approach of "-language-version 1.3 -Xskip-metadata-version-check" because it's simpler and does not cause pre-release binaries to be produced
38 lines
648 B
Kotlin
Vendored
38 lines
648 B
Kotlin
Vendored
// !USE_EXPERIMENTAL: kotlin.Experimental
|
|
// FILE: api.kt
|
|
|
|
package api
|
|
|
|
@Experimental(Experimental.Level.WARNING)
|
|
@Target(AnnotationTarget.FUNCTION)
|
|
annotation class ExperimentalAPI1
|
|
|
|
@Experimental(Experimental.Level.WARNING)
|
|
@Target(AnnotationTarget.FUNCTION)
|
|
annotation class ExperimentalAPI2
|
|
|
|
@ExperimentalAPI1
|
|
fun compilation() {}
|
|
|
|
@ExperimentalAPI2
|
|
fun runtime() {}
|
|
|
|
// FILE: usage.kt
|
|
|
|
@file:UseExperimental(ExperimentalAPI1::class)
|
|
package usage
|
|
|
|
import api.*
|
|
|
|
fun use() {
|
|
compilation()
|
|
<!EXPERIMENTAL_API_USAGE!>runtime<!>()
|
|
}
|
|
|
|
class Use {
|
|
fun use() {
|
|
compilation()
|
|
<!EXPERIMENTAL_API_USAGE!>runtime<!>()
|
|
}
|
|
}
|