view tests/rpat.lac @ 183:c0ea24dcb86f

Optimizing 'case' in Mono_reduce
author Adam Chlipala <adamc@hcoop.net>
date Sun, 03 Aug 2008 13:30:27 -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