blob: 309168c1e0c72a4c86f50de5b4bbcc721433cff7 (
plain) (
tree)
|
|
object Test {
trait A[T]
trait B[U, V] extends A[U with V] // indirect constraint
trait C
trait D
val x: A[C with D] = new B[C, D] {}
val y: A[C with D] = x match { case b: B[u, v] => (new B[u, v] {}): A[u with v] } // OK
def f[T, U](p: A[T with U]): A[T with U] = p match { case b: B[u, v] => new A[u with v] {} } // Not OK
}
object Test1 {
trait T[U, V <: U]
def f(r: Any) = r match {
case t: T[u, v] => new T[u, v]{}
}
}
object Test2 {
trait T[U, V <: U]
val x: T[Int, Int] = new T[Int, Int]{}
x match {
case t: T[u, v] => new T[u, v]{}
}
}
|