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