view lib/basis.lig @ 139:adfa2c7a75da

Form binding parameters threaded through
author Adam Chlipala <adamc@hcoop.net>
date Sun, 20 Jul 2008 10:11:16 -0400
parents 7fdc146b2bc2
children f214c535d253
line wrap: on
line source
type int
type float
type string

type unit = {}


con tag :: {Type} -> {Unit} -> {Unit} -> {Type} -> {Type} -> Type


con xml :: {Unit} -> {Type} -> {Type} -> Type
val cdata : ctx ::: {Unit} -> use ::: {Type} -> bind ::: {Type} -> string -> xml ctx use bind
val tag : attrsGiven ::: {Type} -> attrsAbsent ::: {Type} -> attrsGiven ~ attrsAbsent
        -> ctxOuter ::: {Unit} -> ctxInner ::: {Unit}
        -> useOuter ::: {Type} -> useInner ::: {Type} -> useOuter ~ useInner
        -> bindOuter ::: {Type} -> bindInner ::: {Type} -> bindOuter ~ bindInner
        -> $attrsGiven
        -> tag (attrsGiven ++ attrsAbsent) ctxOuter ctxInner useOuter bindOuter
        -> xml ctxInner useInner bindInner
        -> xml ctxOuter (useOuter ++ useInner) (bindOuter ++ bindInner)
val join : sharedCtx :: {Unit}
        -> ctx1 ::: {Unit} -> ctx1 ~ sharedCtx
        -> ctx2 ::: {Unit} -> ctx2 ~ sharedCtx
        -> use1 ::: {Type} -> bind1 ::: {Type} -> bind2 ::: {Type}
        -> use1 ~ bind1 -> bind1 ~ bind2
        -> xml (sharedCtx ++ ctx1) use1 bind1
        -> xml (sharedCtx ++ ctx2) (use1 ++ bind1) bind2
        -> xml sharedCtx use1 (bind1 ++ bind2)


con xhtml = xml [Html]
con page = xhtml [] []

val head : tag [] [Html] [Head] [] []
val title : tag [] [Head] [] [] []

val body : tag [] [Html] [Body] [] []
val p : tag [] [Body] [Body] [] []
val b : tag [] [Body] [Body] [] []
val i : tag [] [Body] [Body] [] []
val font : tag [Size = int, Face = string] [Body] [Body] [] []

val h1 : tag [] [Body] [Body] [] []
val li : tag [] [Body] [Body] [] []

val a : tag [Link = page] [Body] [Body] [] []