2010-03-06 00:30:06 +00:00
|
|
|
(* RUN: %ocamlopt -warn-error A unix.cmxa llvm.cmxa llvm_bitwriter.cmxa %s -o %t
|
2007-09-18 12:49:39 +00:00
|
|
|
* RUN: ./%t %t.bc
|
|
|
|
* RUN: llvm-dis < %t.bc | grep caml_int_ty
|
|
|
|
*)
|
|
|
|
|
|
|
|
(* Note that this takes a moment to link, so it's best to keep the number of
|
|
|
|
individual tests low. *)
|
|
|
|
|
2009-08-19 17:32:24 +00:00
|
|
|
let context = Llvm.global_context ()
|
|
|
|
|
2007-09-18 12:49:39 +00:00
|
|
|
let test x = if not x then exit 1 else ()
|
|
|
|
|
2010-03-06 00:30:06 +00:00
|
|
|
let read_file name =
|
|
|
|
let ic = open_in_bin name in
|
|
|
|
let len = in_channel_length ic in
|
|
|
|
let buf = String.create len in
|
|
|
|
|
|
|
|
test ((input ic buf 0 len) = len);
|
|
|
|
|
|
|
|
close_in ic;
|
|
|
|
|
|
|
|
buf
|
|
|
|
|
|
|
|
let temp_bitcode ?unbuffered m =
|
|
|
|
let temp_name, temp_oc = Filename.open_temp_file ~mode:[Open_binary] "" "" in
|
|
|
|
|
|
|
|
test (Llvm_bitwriter.output_bitcode ?unbuffered temp_oc m);
|
|
|
|
flush temp_oc;
|
|
|
|
|
|
|
|
let temp_buf = read_file temp_name in
|
|
|
|
|
|
|
|
close_out temp_oc;
|
|
|
|
|
|
|
|
temp_buf
|
|
|
|
|
2007-09-18 12:49:39 +00:00
|
|
|
let _ =
|
2009-08-19 17:32:24 +00:00
|
|
|
let m = Llvm.create_module context "ocaml_test_module" in
|
2007-09-18 12:49:39 +00:00
|
|
|
|
2009-08-19 17:32:24 +00:00
|
|
|
ignore (Llvm.define_type_name "caml_int_ty" (Llvm.i32_type context) m);
|
2010-03-06 00:30:06 +00:00
|
|
|
|
|
|
|
test (Llvm_bitwriter.write_bitcode_file m Sys.argv.(1));
|
|
|
|
let file_buf = read_file Sys.argv.(1) in
|
|
|
|
|
|
|
|
test (file_buf = temp_bitcode m);
|
|
|
|
test (file_buf = temp_bitcode ~unbuffered:false m);
|
|
|
|
test (file_buf = temp_bitcode ~unbuffered:true m)
|