Mercurial > urweb
view tests/foldm.ur @ 1906:0d2fdc2cc46c
Allow building in a separate build directory
Signed-off-by: Anders Kaseorg <andersk@mit.edu>
---
Makefile.am | 30 +++---
src/c/Makefile.am | 2 +-
src/compiler.mlb | 2 +-
src/sources | 302 +++++++++++++++++++++++++++---------------------------
4 files changed, 168 insertions(+), 168 deletions(-)
author | Anders Kaseorg <andersk@mit.edu> |
---|---|
date | Fri, 22 Nov 2013 09:36:14 -0500 |
parents | 71bafe66dbe1 |
children |
line wrap: on
line source
con currier = fold (fn nm => fn t => fn acc => t -> acc) {} signature S = sig type t val x : t con rs :: {Type} val create : currier rs -> t end functor Currier (M : sig con rs :: {Type} end) : S where con rs = M.rs = struct val currier : rs :: {Type} -> currier rs = fold [currier] (fn nm :: Name => fn t :: Type => fn rest :: {Type} => fn acc => fn x : t => acc) {} type t = currier M.rs val x = currier [M.rs] con rs = M.rs val create : t -> t = fn x => x end structure ChefsSpecial = Currier(struct con rs = [A = int, B = float] end) val main = ChefsSpecial.x