JVM_IR no static inline class members for Kotlin JvmDefault methods

KT-43698 KT-43051
This commit is contained in:
Dmitry Petrov
2020-12-02 14:58:05 +03:00
parent 11673bd09c
commit e6a3e38c4d
29 changed files with 1044 additions and 43 deletions
@@ -0,0 +1,38 @@
// JVM_TARGET: 1.8
// FILE: javaDefaultInterfaceMember.kt
interface KFoo2 : JIFoo
interface KFooUnrelated {
fun foo()
}
interface KFoo3 : KFoo2, KFooUnrelated {
override fun foo() {}
}
interface KBar2 : JIBar
inline class TestFoo1(val x: Int) : JIFoo
inline class TestFoo2(val x: Int) : KFoo2
inline class TestFoo3(val x: Int) : KFoo3
inline class TestBar1(val x: Int) : JIBar {
override fun bar() {}
}
inline class TestBar2(val x: Int) : KBar2 {
override fun bar() {}
}
// FILE: JIFoo.java
public interface JIFoo {
default void foo() {}
}
// FILE: JIBar.java
public interface JIBar {
default void foo() {}
default void bar() {}
}
@@ -0,0 +1,130 @@
@kotlin.Metadata
public interface KBar2 {
// source: 'javaDefaultInterfaceMember.kt'
}
@kotlin.Metadata
public interface KFoo2 {
// source: 'javaDefaultInterfaceMember.kt'
}
@kotlin.Metadata
public final class KFoo3$DefaultImpls {
// source: 'javaDefaultInterfaceMember.kt'
public static method foo(@org.jetbrains.annotations.NotNull p0: KFoo3): void
public final inner class KFoo3$DefaultImpls
}
@kotlin.Metadata
public interface KFoo3 {
// source: 'javaDefaultInterfaceMember.kt'
public abstract method foo(): void
public final inner class KFoo3$DefaultImpls
}
@kotlin.Metadata
public interface KFooUnrelated {
// source: 'javaDefaultInterfaceMember.kt'
public abstract method foo(): void
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class TestBar1 {
// source: 'javaDefaultInterfaceMember.kt'
private final field x: int
private synthetic method <init>(p0: int): void
public method bar(): void
public static method bar-impl(p0: int): void
public synthetic final static method box-impl(p0: int): TestBar1
public static method constructor-impl(p0: int): int
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: int, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: int, p1: int): boolean
public final method getX(): int
public method hashCode(): int
public static method hashCode-impl(p0: int): int
public method toString(): java.lang.String
public static method toString-impl(p0: int): java.lang.String
public synthetic final method unbox-impl(): int
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class TestBar2 {
// source: 'javaDefaultInterfaceMember.kt'
private final field x: int
private synthetic method <init>(p0: int): void
public method bar(): void
public static method bar-impl(p0: int): void
public synthetic final static method box-impl(p0: int): TestBar2
public static method constructor-impl(p0: int): int
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: int, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: int, p1: int): boolean
public final method getX(): int
public method hashCode(): int
public static method hashCode-impl(p0: int): int
public method toString(): java.lang.String
public static method toString-impl(p0: int): java.lang.String
public synthetic final method unbox-impl(): int
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class TestFoo1 {
// source: 'javaDefaultInterfaceMember.kt'
private final field x: int
private synthetic method <init>(p0: int): void
public synthetic final static method box-impl(p0: int): TestFoo1
public static method constructor-impl(p0: int): int
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: int, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: int, p1: int): boolean
public final method getX(): int
public method hashCode(): int
public static method hashCode-impl(p0: int): int
public method toString(): java.lang.String
public static method toString-impl(p0: int): java.lang.String
public synthetic final method unbox-impl(): int
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class TestFoo2 {
// source: 'javaDefaultInterfaceMember.kt'
private final field x: int
private synthetic method <init>(p0: int): void
public synthetic final static method box-impl(p0: int): TestFoo2
public static method constructor-impl(p0: int): int
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: int, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: int, p1: int): boolean
public final method getX(): int
public method hashCode(): int
public static method hashCode-impl(p0: int): int
public method toString(): java.lang.String
public static method toString-impl(p0: int): java.lang.String
public synthetic final method unbox-impl(): int
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class TestFoo3 {
// source: 'javaDefaultInterfaceMember.kt'
private final field x: int
private synthetic method <init>(p0: int): void
public synthetic final static method box-impl(p0: int): TestFoo3
public static method constructor-impl(p0: int): int
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: int, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: int, p1: int): boolean
public method foo(): void
public static method foo-impl(p0: int): void
public final method getX(): int
public method hashCode(): int
public static method hashCode-impl(p0: int): int
public method toString(): java.lang.String
public static method toString-impl(p0: int): java.lang.String
public synthetic final method unbox-impl(): int
}
@@ -0,0 +1,18 @@
// !JVM_DEFAULT_MODE: all
// WITH_RUNTIME
// JVM_TARGET: 1.8
interface IFooBar {
fun foo() = "O"
fun bar() = "Failed"
}
interface IFooBar2 : IFooBar
inline class Test1(val k: String): IFooBar {
override fun bar(): String = k
}
inline class Test2(val k: String): IFooBar2 {
override fun bar(): String = k
}
@@ -0,0 +1,53 @@
@kotlin.Metadata
public interface IFooBar {
// source: 'jvmDefaultAll.kt'
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public @org.jetbrains.annotations.NotNull method foo(): java.lang.String
}
@kotlin.Metadata
public interface IFooBar2 {
// source: 'jvmDefaultAll.kt'
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test1 {
// source: 'jvmDefaultAll.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test1
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test2 {
// source: 'jvmDefaultAll.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test2
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@@ -0,0 +1,53 @@
@kotlin.Metadata
public interface IFooBar {
// source: 'jvmDefaultAll.kt'
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public @org.jetbrains.annotations.NotNull method foo(): java.lang.String
}
@kotlin.Metadata
public interface IFooBar2 {
// source: 'jvmDefaultAll.kt'
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test1 {
// source: 'jvmDefaultAll.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test1
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test2 {
// source: 'jvmDefaultAll.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test2
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@@ -0,0 +1,18 @@
// !JVM_DEFAULT_MODE: enable
// WITH_RUNTIME
// JVM_TARGET: 1.8
interface IFooBar {
@JvmDefault fun foo() = "O"
@JvmDefault fun bar() = "Failed"
}
interface IFooBar2 : IFooBar
inline class Test1(val k: String): IFooBar {
override fun bar(): String = k
}
inline class Test2(val k: String): IFooBar2 {
override fun bar(): String = k
}
@@ -0,0 +1,53 @@
@kotlin.Metadata
public interface IFooBar {
// source: 'jvmDefaultEnable.kt'
public @kotlin.jvm.JvmDefault @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public @kotlin.jvm.JvmDefault @org.jetbrains.annotations.NotNull method foo(): java.lang.String
}
@kotlin.Metadata
public interface IFooBar2 {
// source: 'jvmDefaultEnable.kt'
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test1 {
// source: 'jvmDefaultEnable.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test1
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test2 {
// source: 'jvmDefaultEnable.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test2
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@@ -0,0 +1,53 @@
@kotlin.Metadata
public interface IFooBar {
// source: 'jvmDefaultEnable.kt'
public @kotlin.jvm.JvmDefault @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public @kotlin.jvm.JvmDefault @org.jetbrains.annotations.NotNull method foo(): java.lang.String
}
@kotlin.Metadata
public interface IFooBar2 {
// source: 'jvmDefaultEnable.kt'
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test1 {
// source: 'jvmDefaultEnable.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test1
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}
@kotlin.jvm.JvmInline
@kotlin.Metadata
public final class Test2 {
// source: 'jvmDefaultEnable.kt'
private final @org.jetbrains.annotations.NotNull field k: java.lang.String
private synthetic method <init>(p0: java.lang.String): void
public @org.jetbrains.annotations.NotNull method bar(): java.lang.String
public static @org.jetbrains.annotations.NotNull method bar-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public synthetic final static method box-impl(p0: java.lang.String): Test2
public static @org.jetbrains.annotations.NotNull method constructor-impl(@org.jetbrains.annotations.NotNull p0: java.lang.String): java.lang.String
public method equals(p0: java.lang.Object): boolean
public static method equals-impl(p0: java.lang.String, p1: java.lang.Object): boolean
public final static method equals-impl0(p0: java.lang.String, p1: java.lang.String): boolean
public final @org.jetbrains.annotations.NotNull method getK(): java.lang.String
public method hashCode(): int
public static method hashCode-impl(p0: java.lang.String): int
public method toString(): java.lang.String
public static method toString-impl(p0: java.lang.String): java.lang.String
public synthetic final method unbox-impl(): java.lang.String
}