caa1570e25
The patch fixes the js function signature rules to avoid clashes between bridge and delegated call. Use overridden symbols dfs of JsName annotation in order to get the correct bridge name. ^KT-52968 Fixed
37 lines
1.3 KiB
Kotlin
Vendored
37 lines
1.3 KiB
Kotlin
Vendored
@JsExport
|
|
abstract class TestOpenClass {
|
|
@JsName("testName")
|
|
abstract fun testFunction(): String
|
|
abstract fun testFunction(x: String): String
|
|
}
|
|
|
|
abstract class TestOpenClassA : TestOpenClass() {
|
|
override abstract fun testFunction(): String
|
|
override abstract fun testFunction(x: String): String
|
|
}
|
|
|
|
class TestClassA : TestOpenClassA() {
|
|
override fun testFunction(): String = "TestClassA"
|
|
override fun testFunction(x: String): String = "TestClassA: ${x}"
|
|
}
|
|
|
|
fun testTestOpenClass1(x: TestOpenClass) = x.testFunction()
|
|
fun testTestOpenClass2(x: TestOpenClass) = x.testFunction("OK")
|
|
|
|
fun testTestOpenClassA1(x: TestOpenClassA) = x.testFunction()
|
|
fun testTestOpenClassA2(x: TestOpenClassA) = x.testFunction("OK")
|
|
|
|
fun testTestClassA1(x: TestClassA) = x.testFunction()
|
|
fun testTestClassA2(x: TestClassA) = x.testFunction("OK")
|
|
|
|
fun box(): String {
|
|
assertEquals("TestClassA", testTestOpenClass1(TestClassA()))
|
|
assertEquals("TestClassA: OK", testTestOpenClass2(TestClassA()))
|
|
assertEquals("TestClassA", testTestOpenClassA1(TestClassA()))
|
|
assertEquals("TestClassA: OK", testTestOpenClassA2(TestClassA()))
|
|
assertEquals("TestClassA", testTestClassA1(TestClassA()))
|
|
assertEquals("TestClassA: OK", testTestClassA2(TestClassA()))
|
|
|
|
return "OK"
|
|
}
|