summaryrefslogtreecommitdiff
path: root/test/files/neg/t6680a.scala
blob: 93b796438fb9a91ac902ffd10f5417848c7c2013 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
case class Cell[A](var x: A)
object Test {
  def f1(x: Any)        = x match { case y @ Cell(_) => y } // Inferred type is Cell[Any]
  def f2(x: Cell[_])    = x match { case y @ Cell(_) => y } // Inferred type is Cell[_]
  def f3[A](x: Cell[A]) = x match { case y @ Cell(_) => y } // Inferred type is Cell[A]

  def main(args: Array[String]): Unit = {
    val x = new Cell(1)
    val y = f1(x)
    y.x = "abc"
    println(x.x + 1)
  }
}

// The tweetable variation
object Tweet {
  case class C[A](f:A=>A);def f(x:Any)=x match { case C(f)=>f("") };f(C[Int](x=>x))
}