blob: 6c9c3d7714d66bd1b11ddfb39441850213f11663 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
(* TEST
include systhreads;
hassysthreads;
{
bytecode;
}{
native;
}
*)
open Event
type 'a swap_chan = ('a * 'a channel) channel
let swap msg_out ch =
guard (fun () ->
let ic = new_channel() in
choose [
wrap (receive ch) (fun (msg_in, oc) -> sync (send oc msg_out); msg_in);
wrap (send ch (msg_out, ic)) (fun () -> sync (receive ic))
])
let ch = new_channel()
let f () =
let res = sync (swap "F" ch) in
print_string "f "; print_string res; print_newline()
let g () =
let res = sync (swap "G" ch) in
print_string "g "; print_string res; print_newline()
let _ =
let id = Thread.create f () in
g ();
Thread.join id
|