view tests/rpat.lac @ 176:33d4a8eea484

Case through explify
author Adam Chlipala <adamc@hcoop.net>
date Thu, 31 Jul 2008 16:28:55 -0400
parents b2d752455182
children
line wrap: on
line source
val f = fn x : {A : int} => case x of {A = _} => 0
val f = fn x : {A : int} => case x of {A = _, ...} => 0
val f = fn x : {A : int, B : int} => case x of {A = _, ...} => 0
val f = fn x : {A : int, B : int} => case x of {A = 1, B = 2} => 0 | {A = _, ...} => 1

datatype t = A | B

val f = fn x => case x of {A = A, B = 2} => 0 | {A = A, ...} => 0 | {A = B, ...} => 0

val f = fn x => case x of {A = {A = A, ...}, B = B} => 0
        | {B = A, ...} => 1
        | {A = {A = B, B = A}, B = B} => 2
        | {A = {A = B, B = B}, B = B} => 3