blob: 87314864f29d8d8f20c8245f78470a8e12da5b60 (
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
|
(* TEST
include unix
modules = "test2_.c"
* libunix
** bytecode
** native
*)
(* Tests nested calls from C (main C) to OCaml (main OCaml) to C (caml_to_c) to
* OCaml (c_to_caml) to C (printf functions). *)
let printf = Printf.printf
let c_to_caml () =
printf "[Caml] Enter c_to_caml\n%!";
printf "[Caml] Leave c_to_caml\n%!"
let _ = Callback.register "c_to_caml" c_to_caml
external caml_to_c : unit -> unit = "caml_to_c"
let _ =
printf "[Caml] Call caml_to_c\n%!";
caml_to_c ();
printf "[Caml] Return from caml_to_c\n%!"
|