Mercurial > urweb
view tests/roundTrip.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 | 7c6b6c3c7b79 |
children | 8a169fc0838b |
line wrap: on
line source
table channels : { Client : client, Channel : channel (string * int * float) } PRIMARY KEY Client fun writeBack v = me <- self; r <- oneRow (SELECT channels.Channel FROM channels WHERE channels.Client = {[me]}); send r.Channels.Channel v fun main () = me <- self; ch <- channel; dml (INSERT INTO channels (Client, Channel) VALUES ({[me]}, {[ch]})); buf <- Buffer.create; let fun receiverA () = v <- recv ch; Buffer.write buf ("A:(" ^ v.1 ^ ", " ^ show v.2 ^ ", " ^ show v.3 ^ ")"); receiverA () fun receiverB () = v <- recv ch; Buffer.write buf ("B:(" ^ v.1 ^ ", " ^ show v.2 ^ ", " ^ show v.3 ^ ")"); error <xml>Bail out!</xml>; receiverB () fun sender s n f = sleep 2000; writeBack (s, n, f); sender (s ^ "!") (n + 1) (f + 1.23) in return <xml><body onload={onDisconnect (alert "Server booted me"); onConnectFail (alert "Connection failed"); onServerError (fn s => alert ("Server error: " ^ s)); spawn (receiverA ()); spawn (receiverB ()); sender "" 0 0.0}> <dyn signal={Buffer.render buf}/> </body></xml> end