Mercurial > urweb
view demo/more/checkGroup.ur @ 1248:cf9a636f9b15
Avoid state space explosion with ECase that just writes a constant in each case
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Sun, 18 Apr 2010 20:06:15 -0400 |
parents | 7facf72aaf0a |
children |
line wrap: on
line source
con t ctx data = list (data * xml ctx [] [] * source bool) fun create [ctx] [data] (items : list (data * xml ctx [] [] * bool)) = List.mapM (fn (d, x, b) => s <- source b; return (d, x, s)) items fun render [ctx] [data] [[Body] ~ ctx] (t : t ([Body] ++ ctx) data) = List.mapX (fn (_, x, s) => <xml><ccheckbox source={s}/> {x}<br/></xml>) t fun selected [ctx] [data] (t : t ctx data) = List.foldlM (fn (d, _, s) ls => s <- signal s; return (if s then d :: ls else ls)) [] t