f624800b84
I was forced to manually do update the following files, because otherwise they would be ignored according .gitignore settings. Probably they should be deleted from repo. Interop/.idea/compiler.xml Interop/.idea/gradle.xml Interop/.idea/libraries/Gradle__org_jetbrains_kotlin_kotlin_runtime_1_0_3.xml Interop/.idea/libraries/Gradle__org_jetbrains_kotlin_kotlin_stdlib_1_0_3.xml Interop/.idea/modules.xml Interop/.idea/modules/Indexer/Indexer.iml Interop/.idea/modules/Runtime/Runtime.iml Interop/.idea/modules/StubGenerator/StubGenerator.iml backend.native/backend.native.iml backend.native/bc.frontend/bc.frontend.iml backend.native/cli.bc/cli.bc.iml backend.native/cli.bc/src/org/jetbrains/kotlin/cli/bc/K2Native.kt backend.native/cli.bc/src/org/jetbrains/kotlin/cli/bc/K2NativeCompilerArguments.kt backend.native/tests/link/lib/foo.kt backend.native/tests/link/lib/foo2.kt backend.native/tests/teamcity-test.property
86 lines
2.0 KiB
Kotlin
86 lines
2.0 KiB
Kotlin
/*
|
|
* Copyright 2010-2019 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license
|
|
* that can be found in the LICENSE file.
|
|
*/
|
|
|
|
package codegen.associatedObjects.associatedObjects1
|
|
|
|
import kotlin.test.*
|
|
import kotlin.reflect.*
|
|
|
|
@Test
|
|
@OptIn(ExperimentalAssociatedObjects::class)
|
|
fun testBasics1() {
|
|
assertSame(Bar, Foo::class.findAssociatedObject<Associated1>())
|
|
assertSame(Baz, Foo::class.findAssociatedObject<Associated2>())
|
|
assertSame(null, Foo::class.findAssociatedObject<Associated3>())
|
|
|
|
assertSame(null, Bar::class.findAssociatedObject<Associated1>())
|
|
}
|
|
|
|
@OptIn(ExperimentalAssociatedObjects::class)
|
|
@AssociatedObjectKey
|
|
@Retention(AnnotationRetention.BINARY)
|
|
annotation class Associated1(val kClass: KClass<*>)
|
|
|
|
@OptIn(ExperimentalAssociatedObjects::class)
|
|
@AssociatedObjectKey
|
|
@Retention(AnnotationRetention.BINARY)
|
|
annotation class Associated2(val kClass: KClass<*>)
|
|
|
|
@OptIn(ExperimentalAssociatedObjects::class)
|
|
@AssociatedObjectKey
|
|
@Retention(AnnotationRetention.BINARY)
|
|
annotation class Associated3(val kClass: KClass<*>)
|
|
|
|
@Associated1(Bar::class)
|
|
@Associated2(Baz::class)
|
|
class Foo
|
|
|
|
object Bar
|
|
object Baz
|
|
|
|
@Test
|
|
@OptIn(ExperimentalAssociatedObjects::class)
|
|
fun testGlobalOptimizations1() {
|
|
val i1 = I1ImplHolder::class.findAssociatedObject<Associated1>()!! as I1
|
|
assertEquals(42, i1.foo())
|
|
val c = C(null)
|
|
i1.bar(c)
|
|
assertEquals("zzz", c.list!![0])
|
|
}
|
|
|
|
private class C(var list: List<String>?)
|
|
|
|
private interface I1 {
|
|
fun foo(): Int
|
|
fun bar(c: C)
|
|
}
|
|
|
|
private object I1Impl : I1 {
|
|
override fun foo() = 42
|
|
override fun bar(c: C) {
|
|
c.list = mutableListOf("zzz")
|
|
}
|
|
}
|
|
|
|
@Associated1(I1Impl::class)
|
|
private class I1ImplHolder
|
|
|
|
@Test
|
|
@OptIn(ExperimentalAssociatedObjects::class)
|
|
fun testGlobalOptimizations2() {
|
|
val i2 = I2ImplHolder()::class.findAssociatedObject<Associated1>()!! as I2
|
|
assertEquals(17, i2.foo())
|
|
}
|
|
|
|
private interface I2 {
|
|
fun foo(): Int
|
|
}
|
|
|
|
private object I2Impl : I2 {
|
|
override fun foo() = 17
|
|
}
|
|
|
|
@Associated1(I2Impl::class)
|
|
private class I2ImplHolder |