view tests/rpat.ur @ 1176:51e596feec37

Tone down Reduce and compensate with a new push-lambda-inside-case rule in MonoOpt; expand more Basis synonyms in Monoize
author Adam Chlipala <adamc@hcoop.net>
date Tue, 02 Mar 2010 16:00:48 -0500
parents 71bafe66dbe1
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