Mercurial > urweb
annotate tests/rpcDE.ur @ 1249:7c6fc92f6c31
Complain about DValRec; optimizations for unit-valued ECase and forgetting of path conditions across ESeq
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Thu, 29 Apr 2010 11:47:24 -0400 |
parents | 3ee6bb48f6e8 |
children |
rev | line source |
---|---|
adamc@638 | 1 datatype result = Neg | Zero | Pos |
adamc@638 | 2 |
adamc@638 | 3 table t : {A : int} |
adamc@638 | 4 |
adamc@638 | 5 fun main () : transaction page = |
adamc@638 | 6 let |
adamc@638 | 7 fun check () = |
adamc@638 | 8 r <- oneRow (SELECT SUM(t.A) AS X FROM t); |
adamc@638 | 9 return (if r.X < 0 then |
adamc@638 | 10 Neg |
adamc@638 | 11 else if r.X = 0 then |
adamc@638 | 12 Zero |
adamc@638 | 13 else |
adamc@638 | 14 Pos) |
adamc@638 | 15 |
adamc@638 | 16 fun show r = |
adamc@638 | 17 case r of |
adamc@638 | 18 Neg => <xml>-</xml> |
adamc@638 | 19 | Zero => <xml>0</xml> |
adamc@638 | 20 | Pos => <xml>+</xml> |
adamc@638 | 21 in |
adamc@638 | 22 s <- source Zero; |
adamc@638 | 23 return <xml><body> |
adamc@638 | 24 <button value="Get It On!" |
adamc@638 | 25 onclick={r <- check (); |
adamc@638 | 26 set s r}/><br/> |
adamc@638 | 27 <br/> |
adamc@638 | 28 Current: <dyn signal={r <- signal s; return (show r)}/> |
adamc@638 | 29 </body></xml> |
adamc@638 | 30 end |