summaryrefslogtreecommitdiff
path: root/test/pending/pos/pattern-typing.scala
blob: 7286cc38afdd920f371e3eb35b3a4582b3b1da2d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import scala.language.higherKinds

trait Bound[B]

package p1 {
  case class Sub[B <: Bound[B]](p: B)
  object Test {
    def g[A](x: Bound[A]) = ()
    def f(x: Any) = x match { case Sub(p) => g(p) }
  }
}

package p2 {
  trait Traversable[+A] { def head: A = ??? }
  trait Seq[+A] extends Traversable[A] { def length: Int = ??? }

  case class SubHK[B <: Bound[B], CC[X] <: Traversable[X]](xs: CC[B])
  class MyBound extends Bound[MyBound]
  class MySeq extends Seq[MyBound]

  object Test {
    def g[B](x: Bound[B]) = ()

    def f1(x: Any) = x match { case SubHK(xs) => xs }
    def f2[B <: Bound[B], CC[X] <: Traversable[X]](sub: SubHK[B, CC]): CC[B] = sub match { case SubHK(xs) => xs }
    def f3 = g(f1(SubHK(new MySeq)).head)
    def f4 = g(f2(SubHK(new MySeq)).head)
  }
}