C and Objective Caml bindings for several scalar transforms.
[oota-llvm.git] / test / Bindings / Ocaml / scalar_opts.ml
1 (* RUN: %ocamlc -warn-error A llvm.cma llvm_scalar_opts.cma %s -o %t
2  *)
3
4 (* Note: It takes several seconds for ocamlc to link an executable with
5          libLLVMCore.a, so it's better to write a big test than a bunch of
6          little ones. *)
7
8 open Llvm
9 open Llvm_scalar_opts
10
11
12 (* Tiny unit test framework - really just to help find which line is busted *)
13 let suite name f =
14   prerr_endline (name ^ ":");
15   f ()
16
17
18 (*===-- Fixture -----------------------------------------------------------===*)
19
20 let filename = Sys.argv.(1)
21 let m = create_module filename
22 let mp = ModuleProvider.create m
23
24
25 (*===-- Transforms --------------------------------------------------------===*)
26
27 let test_transforms () =
28   let (++) x f = ignore (f x); x in
29
30   let fty = function_type void_type [| |] in
31   let fn = define_function "fn" fty m in
32   ignore (build_ret_void (builder_at_end (entry_block fn)));
33   
34   ignore (PassManager.create_function mp
35         (* ++ add_instruction_combining  Requires target data. *)
36            ++ add_reassociation
37            ++ add_gvn
38            ++ add_cfg_simplification
39            ++ add_constant_propagation
40            ++ PassManager.initialize
41            ++ PassManager.run_function fn
42            ++ PassManager.finalize
43            ++ PassManager.dispose)
44
45
46 (*===-- Driver ------------------------------------------------------------===*)
47
48 let _ =
49   suite "transforms" test_transforms;
50   ModuleProvider.dispose mp