File: virtpatmat_exhaust.scala

package info (click to toggle)
scala 2.11.12-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 62,924 kB
  • sloc: javascript: 28,808; java: 13,415; xml: 3,135; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (24 lines) | stat: -rw-r--r-- 762 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
sealed trait Option {}
case class Choice(a: Option, b: Option) extends Option;
case class Some(x: Boolean) extends Option;
case object None extends Option;

object test {

// drop any case and it will report an error
// note that booleans are taken into account
  def f(opt: Option) = opt match {
    case Choice(None, None) => 1;
    case Choice(None, Some(_)) => 1;
    case Choice(None, Choice(_, _)) => 1;
    case Choice(Some(true), None) => 1;
    case Choice(Some(false), None) => 1;
    case Choice(Some(_), Some(_)) => 1;
    case Choice(Some(_), Choice(_, _)) => 1;
    case Choice(Choice(_, _), None) => 1;
    case Choice(Choice(_, _), Some(_)) => 1;
    case Choice(Choice(_, _), Choice(_, _)) => 1;
    case Some(b) => 4;
    case None => 5;
  }
}