Mercurial > urweb
view tests/functor.ur @ 1455:913d9c2f55c9
Corify Basis.unit to empty record; this is needed so that specialize
can see that they are equivalent.
author | Karn Kallio <kkallio@eka> |
---|---|
date | Fri, 06 May 2011 16:24:45 -0430 |
parents | 71bafe66dbe1 |
children |
line wrap: on
line source
signature S = sig type t val z : t val s : t -> t end signature T = sig type t val three : t end functor F (M : S) : T where type t = M.t = struct type t = M.t val three = M.s (M.s (M.s M.z)) end structure O = F (struct type t = int val z = 0 val s = fn x : t => x end) val three : int = O.three structure S = struct type t = int val z = 0 val s = fn x : t => x end structure SO = F (S) val three : int = SO.three structure SS : S = S structure SSO = F (SS) val three : SS.t = SSO.three val main = three