view demo/treeFun.urs @ 563:44958d74c43f

Initial conversion to arbitrary-kind classes
author Adam Chlipala <adamc@hcoop.net>
date Fri, 19 Dec 2008 10:03:31 -0500
parents b393c2fc80f8
children 1fb318c17546
line wrap: on
line source
functor Make(M : sig
                 type key
                 con id :: Name
                 con parent :: Name
                 con cols :: {Type}
                 constraint [id] ~ [parent]
                 constraint [id, parent] ~ cols

                 val key_inj : sql_injectable key
                 val option_key_inj : sql_injectable (option key)

                 table tab : [id = key, parent = option key] ++ cols
             end) : sig

    con id = M.id
    con parent = M.parent

    val tree : ($([id = M.key, parent = option M.key] ++ M.cols) -> xbody)
               -> option M.key
               -> transaction xbody

end