f0720c1d12
The compiler should only report diagnostics for
comparisons over builtins and identity-less types,
other incompatibilities should be reported
via inspections.
It's ok that in `equalityChecksOnIntegerTypes`
instead of `EQUALITY_NOT_APPLICABLE_WARNING` we get
`EQUALITY_NOT_APPLICABLE`, because
`ProperEqualityChecksInBuilderInferenceCalls`
is already active by default.
This change also replaces the notion of a representative superclass
with the least upper bound.
This makes complex types like
intersection/flexible transparent to
RULES1-based compatibility checks.
One way to look at it is to think
that this is an automatic way of handling
type parameters: automatic picking of
"interesting" bounds, and checking them against one another.
Note that `TypeIntersector.intersectTypes`
for `Int` and `T` where `T` is a type parameter
may return both `{Int & T}` or `null`
depending on `T`-s bounds. At the same time,
for type parameters `T` and `K` it will
always return `{T & K}`.
`ConeTypeIntersector.intersectTypes`, on the
other hand, will always return `{Int & T}`
irrespectively of the bounds. Meaning, the two
intersectors differ in corner cases.
`lowerBoundIfFlexible` call in `isLiterallyTypeParameter` is backed by
the `equalityOfFlexibleTypeParameters` test.
^KT-35134 #fixed-in-k2
^KT-22499 #fixed-in-k2
^KT-46383 #fixed-in-k2
39 lines
888 B
Kotlin
Vendored
39 lines
888 B
Kotlin
Vendored
// LANGUAGE: +ReportErrorsForComparisonOperators
|
|
|
|
fun nullableNothingIdentity(a: Int, b: Nothing?) {
|
|
a === <!DEBUG_INFO_CONSTANT!>b<!>
|
|
}
|
|
|
|
fun samePrimitiveIdentity(a: Int, b: Int) {
|
|
<!DEPRECATED_IDENTITY_EQUALS!>a === b<!>
|
|
}
|
|
|
|
fun identityWithImplicitBoxing(a: Int, b: Any?) {
|
|
<!IMPLICIT_BOXING_IN_IDENTITY_EQUALS!>a === b<!>
|
|
}
|
|
|
|
enum class E1 { A, B }
|
|
enum class E2 { C, D }
|
|
|
|
fun nullableEnums(a: E1?, b: E2?) {
|
|
a == b
|
|
}
|
|
|
|
fun <T> enumAsTypeParameterBound(a: T, b: Int) where T : Any, T : <!ONLY_ONE_CLASS_BOUND_ALLOWED!>E1<!> {
|
|
<!EQUALITY_NOT_APPLICABLE!>a == b<!>
|
|
}
|
|
|
|
fun <T, K> twoTypeParameters(a: T, b: K) where T : Number, K : <!FINAL_UPPER_BOUND!>String<!> {
|
|
a == b
|
|
}
|
|
|
|
interface I1
|
|
interface I2
|
|
|
|
enum class E3 : I1 { A, B }
|
|
|
|
fun <A> compareTypeParameterWithEnum(a: A) where A: I1, A: I2 {
|
|
<!INCOMPATIBLE_ENUM_COMPARISON_ERROR!>a == E1.A<!>
|
|
a == E3.A
|
|
}
|