summaryrefslogtreecommitdiff
path: root/test/files/run/t2251b.scala
blob: b67b3aec1eb3b2c11087a0abe50d8da6d729bde4 (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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
class A
trait B[T <: B[T]] extends A
class B1[T <: B1[T]] extends B[T]
class C extends B[C] { override def toString = "C" }
class D extends B[D] { override def toString = "D" }
class E extends B[E] { override def toString = "E" }
class F extends B[F] { override def toString = "F" }
class G extends B1[G] { override def toString = "G" }

object Test {
  import scala.collection.{ mutable, immutable }
  import scala.collection.immutable.{ Vector }
  import scala.reflect.runtime.universe._
  def what[T: TypeTag](x: T) = println(typeTag[T])

  def main(args: Array[String]): Unit = {
    what(List(List(new C), Stream(new D)))
    what(List(List(new C), Stream(new D), Vector(new E), Set(new F)))
    what(List(immutable.Vector(new C), Stream(new D)))
    what(List(collection.Set(new F), mutable.Set(new G)))
    what(List(collection.Set(new F), immutable.Set(new G)))
    what(List(mutable.Set(new F), immutable.Set(new G)))
    what(List(mutable.Seq(new F), immutable.Seq(new G)))
    what(List(mutable.Map(new C -> new D), immutable.Map(new F -> new G)))
    what(List(mutable.MutableList(new F), immutable.List(new G)))
    what(List(mutable.Seq(new F), collection.Seq(new G)))
    what(List(mutable.LinearSeq(new F), collection.IndexedSeq(new G)))
  }
}


// class D extends B[D] { override def toString = "D" }


// class E {
//   val ys = List(List(new C), Stream(new D))
// }

// object Test {
//   def trav = List(List(), Stream())

//   def main(args: Array[String]): Unit = {
//     val f = (new E).ys _
//     var xs: Set[List[_ <: Seq[B[_]]]] = Set()
//     xs += f()
//     println(xs)
//   }
// }