628d75c7cd
Pass parentContext to SamWrapperCodegen from the outside instead of using the one from parentCodegen. The difference is that in case of an inline lambda, we're creating an InlineLambdaContext whose parent is a ClosureContext, but the codegen for that lambda has that latter ClosureContext as its context. So the getNonInlineOuterContext call in SamWrapperCodegen.generateInnerClassInformation wasn't able to identify that this is a context of a lambda that needs to be skipped, and generated it as EnclosingMethod, which caused Java reflection to fail because once that lambda was inlined, it was removed and thus didn't make it to runtime. #KT-44827 Fixed
17 lines
745 B
Plaintext
Vendored
17 lines
745 B
Plaintext
Vendored
@kotlin.Metadata
|
|
synthetic final class<null> TKt$sam$Sam$0 {
|
|
// source: 't.kt'
|
|
<null> method <init>(p0: kotlin.jvm.functions.Function0): void
|
|
public synthetic final <null> method get(): java.lang.Object
|
|
enclosing method TKt.genericSam(Lkotlin/jvm/functions/Function0;)Ljava/lang/Object;
|
|
private synthetic final field <null> function: kotlin.jvm.functions.Function0
|
|
inner (anonymous) class TKt$sam$Sam$0
|
|
}
|
|
|
|
@kotlin.Metadata
|
|
public final class<null> TKt {
|
|
// source: 't.kt'
|
|
public final static <<T:Ljava/lang/Object;>(Lkotlin/jvm/functions/Function0<+TT;>;)TT;> method genericSam(@org.jetbrains.annotations.NotNull p0: kotlin.jvm.functions.Function0): java.lang.Object
|
|
inner (anonymous) class TKt$sam$Sam$0
|
|
}
|