mirror of
https://github.com/jlengrand/kotlin.git
synced 2026-05-08 15:53:19 +00:00
- base class method wins against a (default) interface method, so an abstract base class method should always be implemented in a derived class; - interface methods clash regardless of abstract/default with possibly undefined behavior at run-time, so a class or interface should always define its own method for methods inherited from multiple interfaces and not from base class; - meaningful diagnostics for class inheriting conflicting JVM signatures. Since no override will happen under Java 8 rules, ACCIDENTAL_OVERRIDE is misleading for this case; - update testData.
16 lines
333 B
Kotlin
Vendored
16 lines
333 B
Kotlin
Vendored
interface A {
|
|
fun foo(): String
|
|
}
|
|
|
|
interface B {
|
|
fun foo(): String = "OK"
|
|
}
|
|
|
|
interface C : A, B {
|
|
override fun foo(): String = super<B>.foo()
|
|
}
|
|
|
|
// There's no 'foo' in A$DefaultImpls, proguard and other tools may fail if we generate calls to it
|
|
// 0 INVOKESTATIC A\$DefaultImpls.foo
|
|
// 1 INVOKESTATIC B\$DefaultImpls.foo
|