annotate tests/efold.lac @ 159:1e382d10e832

Abstracting datatypes with signature ascription
author Adam Chlipala <adamc@hcoop.net>
date Thu, 24 Jul 2008 16:41:12 -0400
parents 144d082b47ae
children
rev   line source
adamc@71 1 val currier : rs :: {Type} -> Cfold.currier rs =
adamc@74 2 fold [Cfold.currier] (fn nm :: Name => fn t :: Type => fn rest :: {Type} => fn acc => fn x : t => acc) {}
adamc@71 3
adamc@71 4 val greenCurry : Cfold.greenCurry = currier [Cfold.greenCurryIngredients]
adamc@71 5 val redCurry : Cfold.redCurry = currier [Cfold.redCurryIngredients]
adamc@71 6 val yellowCurry : Cfold.yellowCurry = currier [Cfold.yellowCurryIngredients]
adamc@73 7
adamc@73 8 val main = yellowCurry