(* RUN: rm -rf %t && mkdir -p %t && cp %s %t/irreader.ml * RUN: %ocamlc -g -w +A -package llvm.irreader -linkpkg %t/irreader.ml -o %t/executable * RUN: %t/executable * RUN: %ocamlopt -g -w +A -package llvm.irreader -linkpkg %t/irreader.ml -o %t/executable * RUN: %t/executable * XFAIL: vg_leak *) (* Note: It takes several seconds for ocamlopt to link an executable with libLLVMCore.a, so it's better to write a big test than a bunch of little ones. *) open Llvm open Llvm_irreader let context = global_context () (* Tiny unit test framework - really just to help find which line is busted *) let print_checkpoints = false let suite name f = if print_checkpoints then prerr_endline (name ^ ":"); f () let _ = Printexc.record_backtrace true let insist cond = if not cond then failwith "insist" (*===-- IR Reader ---------------------------------------------------------===*) let test_irreader () = begin let buf = MemoryBuffer.of_string "@foo = global i32 42" in let m = parse_ir context buf in match lookup_global "foo" m with | Some foo -> insist ((global_initializer foo) = (const_int (i32_type context) 42)) | None -> failwith "global" end; begin let buf = MemoryBuffer.of_string "@foo = global garble" in try ignore (parse_ir context buf); failwith "parsed" with Llvm_irreader.Error _ -> () end (*===-- Driver ------------------------------------------------------------===*) let _ = suite "irreader" test_irreader