Mercurial > urweb
view tests/espec.ur @ 1077:a3273bee05a9
Initial generalization of Especialize, with security bug known
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Tue, 15 Dec 2009 12:26:00 -0500 |
parents | |
children |
line wrap: on
line source
fun foo (wrap : xbody -> transaction page) = wrap <xml> <a link={foo wrap}>Foo</a> </xml> fun bar (wrap : xbody -> transaction page) (n : int) = wrap <xml> <a link={bar wrap n}>Bar</a>; {[n]} </xml> fun baz (n : int) (wrap : xbody -> transaction page) = wrap <xml> <a link={baz n wrap}>Baz</a>; {[n]} </xml> fun middle (n : int) (wrap : xbody -> transaction page) (m : int) = wrap <xml> <a link={middle n wrap m}>Middle</a>; {[n]}; {[m]} </xml> fun crazy (f : int -> int) (b : bool) (wrap : xbody -> transaction page) (m : int) = wrap <xml> <a link={crazy f b wrap m}>Crazy</a>; {[b]}; {[f m]} </xml> fun wild (q : bool) (f : int -> int) (n : float) (wrap : xbody -> transaction page) (m : int) = wrap <xml> <a link={wild q f n wrap m}>Wild</a>; {[n]}; {[f m]}; {[q]} </xml> fun wrap x = return <xml><body>{x}</body></xml> fun wrapN n x = return <xml><body>{[n]}; {x}</body></xml> fun foo2 (wrap : xbody -> transaction page) = wrap <xml> <a link={foo2 wrap}>Foo</a> </xml> fun foo3 (n : int) = wrap <xml> <a link={foo2 (wrapN n)}>Foo</a> </xml> fun bar2 (n : int) (wrap : xbody -> transaction page) = wrap <xml> <a link={bar2 n wrap}>Bar</a>; n={[n]} </xml> fun bar3 (n : int) = wrap <xml> <a link={bar2 88 (wrapN n)}>Bar</a> </xml> fun main () = return <xml><body> <a link={foo wrap}>Foo</a> <a link={bar wrap 32}>Bar</a> <a link={baz 18 wrap}>Baz</a> <a link={middle 1 wrap 2}>Middle</a> <a link={crazy (fn n => 2 * n) False wrap 2}>Crazy</a> <a link={wild True (fn n => 2 * n) 1.23 wrap 2}>Wild</a> <hr/> <a link={foo3 15}>Foo3</a> <a link={bar3 44}>Bar3</a> </body></xml>