summaryrefslogtreecommitdiff
path: root/test/pending/pos/unapply.scala
blob: 4ddc93120b4db62fbdd4e817e7b47e4cf99ad549 (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
49
50
51
52
53
54
55
object Test {
  def main(args:Array[String]) = {
    Foo.run
    Mas.run
  }
}
object Foo {
  def unapply(x: Any): Option[Product2[Int, String]] = x match {
    case y: Bar => Some(Tuple(y.size, y.name))
    case _ => None
  }/*
  // ERROR: test/pending/pos/unapply.scala:6 error: method unapply is defined twice
  def unapply(x: Any): Option[Product1[String]] = x match {
    case y: Bar => Some(Tuple(y.name))
    case _ => None
  }*/
  def run: Unit = {
    val b = new Bar
    b match {
      case Foo(s:Int, n:String) => Console.println("size "+s+" name "+n)
    }
    b.size = 54
    b.name = "large"
    b match {
      case Foo(s:Int, n:String) => Console.println("size "+s+" name "+n)
    }/*
    b match {
      case Foo(n) => Console.println("name " + n)
    }*/
  }
}

class Bar {
  var size: Int    = 50
  var name: String = "medium"
}

object Mas {
  object Gaz {
    def unapply(x: Any): Option[Product2[Int, String]] = x match {
      case y: Baz => Some(Tuple(y.size, y.name))
      case _ => None
    }
  }
  class Baz {
    var size: Int    = 60
    var name: String = "too large"
  }
  def run: Unit = {
    val b = new Baz
    b match {
      case Gaz(s:Int, n:String) => Console.println("size "+s+" name "+n)
    }
  }
}