7b46c59d57
Before this commit, for property candidates in K2 their types wasn't inferred/susbtituted properly. So, when candidate for fooBar.liveLoaded.invoke() was created, the type of `fooBar.liveLoaded` was just X type parameter for which there is no any `bar()` functions in its member scope. While proposed semantics is a bit different from K1, where both property and invoke candidates are united into common system, it doesn't contradict to the specification (https://kotlinlang.org/spec/overload-resolution.html#callables-and-invoke-convention) which says explicitly that invoke-convention should be desugared as `r.foo.invoke()`, thus `r.foo` should be completed independently. Also, this strategy supports some reasonable use-cases like KT-58259 while it's still a breaking change but for more artificial-looking situations (see KT-58260) and should be passed through the language committee. The changes in stubTypeReceiverRestriction* tests looks consistent because of how `genericLambda` now works (with full completion of property call). NB: The code is going to be red once KT-54667 is fixed and also there's already similar diagnostic in K1 (INFERRED_INTO_DECLARED_UPPER_BOUNDS) ^KT-58142 Fixed ^KT-58259 Fixed ^KT-58260 Related
22 lines
435 B
Kotlin
Vendored
22 lines
435 B
Kotlin
Vendored
// FIR_IDENTICAL
|
|
// ISSUE: KT-58142
|
|
interface XTrackableLoading {
|
|
val <X> Property<LoadingValue<X>>.liveLoaded: X
|
|
get(): X = TODO()
|
|
}
|
|
|
|
interface LoadingValue<T>
|
|
|
|
interface Property<T>
|
|
|
|
interface AsyncModule {
|
|
fun bar() {}
|
|
}
|
|
operator fun <T : AsyncModule, R> T.invoke(handler: T.() -> R): R = TODO()
|
|
|
|
fun XTrackableLoading.foo(fooBar: Property<LoadingValue<AsyncModule>>) {
|
|
fooBar.liveLoaded {
|
|
bar()
|
|
}
|
|
}
|