Mercurial > urweb
annotate tests/gformText.lac @ 168:25b169416ea8
Storing datatype constructors in type references past monoize
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Tue, 29 Jul 2008 15:43:17 -0400 (2008-07-29) |
parents | 6c14e78feb6d |
children |
rev | line source |
---|---|
adamc@151 | 1 con stringify = fold (fn nm :: Name => fn u :: Unit => fn t :: {Type} => [nm = string] ++ t) [] |
adamc@151 | 2 |
adamc@151 | 3 signature S = sig |
adamc@151 | 4 con rs :: {Unit} |
adamc@151 | 5 val names : $(stringify rs) |
adamc@151 | 6 end |
adamc@151 | 7 |
adamc@151 | 8 signature S' = sig |
adamc@151 | 9 con rs :: {Unit} |
adamc@151 | 10 |
adamc@151 | 11 val handler : $(stringify rs) -> page |
adamc@151 | 12 val page : unit -> page |
adamc@151 | 13 end |
adamc@151 | 14 |
adamc@151 | 15 functor F (M : S) : S' where con rs = M.rs = struct |
adamc@151 | 16 con rs = M.rs |
adamc@151 | 17 |
adamc@151 | 18 val handler = fn x : $(stringify M.rs) => <html><body> |
adamc@151 | 19 {fold [fn rs :: {Unit} => $(stringify rs) -> $(stringify rs) -> xml body [] []] |
adamc@151 | 20 (fn nm :: Name => fn u :: Unit => fn rest :: {Unit} => |
adamc@151 | 21 fn f : $(stringify rest) -> $(stringify rest) -> xml body [] [] => |
adamc@151 | 22 fn names : $(stringify ([nm] ++ rest)) => |
adamc@151 | 23 fn x : $(stringify ([nm] ++ rest)) => |
adamc@151 | 24 <body><li> {cdata names.nm}: {cdata x.nm}</li> {f (names -- nm) (x -- nm)}</body>) |
adamc@151 | 25 (fn names => fn x => <body></body>) |
adamc@151 | 26 [M.rs] M.names x} |
adamc@151 | 27 </body></html> |
adamc@151 | 28 |
adamc@151 | 29 val page = fn () => <html><body> |
adamc@151 | 30 <lform> |
adamc@151 | 31 {fold [fn rs :: {Unit} => xml lform [] (stringify rs)] |
adamc@151 | 32 (fn nm :: Name => fn u :: Unit => fn rest :: {Unit} => |
adamc@151 | 33 fn frag : xml lform [] (stringify rest) => |
adamc@151 | 34 <lform><li> <textbox{nm}/></li> {useMore frag}</lform>) |
adamc@151 | 35 <lform></lform> |
adamc@151 | 36 [rs]} |
adamc@151 | 37 |
adamc@151 | 38 <submit action={handler}/> |
adamc@151 | 39 </lform> |
adamc@151 | 40 </body></html> |
adamc@151 | 41 end |
adamc@151 | 42 |
adamc@151 | 43 structure M = F(struct |
adamc@151 | 44 con rs = [A, B, C] |
adamc@151 | 45 |
adamc@151 | 46 val names = {A = "A", B = "B", C = "C"} |
adamc@151 | 47 end) |
adamc@151 | 48 |
adamc@151 | 49 open M |
adamc@151 | 50 |