1(* RUN: %ocamlopt -warn-error A unix.cmxa llvm.cmxa llvm_bitwriter.cmxa %s -o %t
2 * RUN: %t %t.bc
3 * RUN: llvm-dis < %t.bc
4 * XFAIL: vg_leak
5 *)
6
7(* Note that this takes a moment to link, so it's best to keep the number of
8   individual tests low. *)
9
10let context = Llvm.global_context ()
11
12let test x = if not x then exit 1 else ()
13
14let read_file name =
15  let ic = open_in_bin name in
16  let len = in_channel_length ic in
17  let buf = String.create len in
18
19  test ((input ic buf 0 len) = len);
20
21  close_in ic;
22
23  buf
24
25let temp_bitcode ?unbuffered m =
26  let temp_name, temp_oc = Filename.open_temp_file ~mode:[Open_binary] "" "" in
27
28  test (Llvm_bitwriter.output_bitcode ?unbuffered temp_oc m);
29  flush temp_oc;
30
31  let temp_buf = read_file temp_name in
32
33  close_out temp_oc;
34
35  temp_buf
36
37let _ =
38  let m = Llvm.create_module context "ocaml_test_module" in
39
40  test (Llvm_bitwriter.write_bitcode_file m Sys.argv.(1));
41  let file_buf = read_file Sys.argv.(1) in
42
43  test (file_buf = temp_bitcode m);
44  test (file_buf = temp_bitcode ~unbuffered:false m);
45  test (file_buf = temp_bitcode ~unbuffered:true m)
46