view tests/unurlify.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 ebf27030ae3b
children
line wrap: on
line source
datatype list t = Nil | Cons of t * list t

fun handler (ls : list bool) = return <xml/>

datatype wlist = WNil | Empty | WCons of bool * wlist

fun whandler' (ls : wlist) =
    case ls of
        WNil => <xml>Nil</xml>
      | Empty => <xml>Empty</xml>
      | WCons (x, ls') => <xml>{[x]} :: {whandler' ls'}</xml>

fun whandler ls = return (whandler' ls)

fun main () : transaction page = return <xml><body>
  <a link={handler Nil}>!</a><br/>
  <a link={whandler WNil}>Nil</a><br/>
  <a link={whandler Empty}>Empty</a><br/>
  <a link={whandler (WCons (True, WCons (False, Empty)))}>True :: False :: Empty</a><br/>
</body></xml>