blob: 36cb69cf3dbb6a6255f3ab9ad600067faea47e76 (
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
|
case class MyTuple2[A,B](val _1:A, val snd:B)
object FooSeq {
def unapplySeq(x:Any): Option[Product2[Int,Seq[String]]] = {
if(x.isInstanceOf[Bar]) {
val y = x.asInstanceOf[Bar]
Some(MyTuple2(y.size, y.name))
} else None
}
def main(args:Array[String]) = {
val b = new Bar
b match {
case FooSeq(s:Int,_,n:String) => Console.println("size "+s+" name "+n)
}
b.size = 54
b.name = List("large","L")
b match {
case FooSeq(s:Int,_,n:String) => Console.println("size "+s+" name "+n)
}
}
}
class Bar {
var size: Int = 50
var name: List[String] = List("medium","M")
}
|