blob: fe19b48730a6efa4f14ae1ced146548a26e9042c (
plain) (
blame)
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
37
38
39
40
41
42
|
let expect mgs =
let l = read_line () in
begin try
let (s, f) = List.find
(fun (s, _) ->
String.length l >= String.length s
&& String.sub l 0 (String.length s) = s)
mgs
in f (String.sub l (String.length s)
(String.length l - String.length s))
with
Not_found ->
Format.eprintf "Unexpected '%s'.@." l;
exit 1
end
let finished _ =
print_string "Fair enough\n"
let rec turn _ =
expect [
"Your turn",
(fun _ ->
if Random.int 2 = 0 then Unix.sleep 1;
print_string "Play this_is_a_word\n";
expect [ "OK", turn ]);
"Play ", turn;
"Tie", finished;
"You win", finished;
"You lose", finished;
"Eliminated", finished
]
let () =
Random.self_init ();
expect [
"Hello dummy_game",
(fun _ -> print_string "Hello dummy_game\n";
turn "")
];
|