view tests/foldm.ur @ 1905:cd1cfecc8c72

Remove autogenerated config.h.in from version control Signed-off-by: Anders Kaseorg <andersk@mit.edu> --- .hgignore | 1 + include/urweb/config.h.in | 104 ---------------------------------------------- 2 files changed, 1 insertion(+), 104 deletions(-) delete mode 100644 include/urweb/config.h.in
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