blob: efb878211cdc4dbcef202d54aa7a26c1ad2f4def (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
open Ocamlbuild_plugin ;;
open Command ;;
open Pathname ;;
open Outcome ;;
(* paths relative to _build *)
let lem_dir = "../../../lem" ;;
let lem_libdir = lem_dir / "ocaml-lib/_build" ;;
let lem_lib = lem_libdir / "extract" ;;
let lem = lem_dir / "lem" ;;
(* Order matters - respect dependencies! *)
let lem_deps = List.map ((/) "lem_interp") [
"interp_ast.lem";
"interp.lem";
"interp_lib.lem";
] ;;
let lem_opts = List.fold_right (fun s l -> [A "-i"; P s] @ l) lem_deps [] ;;
(* New library magic: *)
let lem_opts = [A "-lib"; P "../lem_interp"] ;;
dispatch begin function
| After_rules ->
(* ocaml_lib "lem_interp/interp"; *)
ocaml_lib ~extern:true ~dir:lem_libdir ~tag_name:"use_lem" lem_lib;
rule "lem -> ml"
~prod: "%.ml"
~dep: "%.lem"
(fun env builder -> Seq [
Cmd (S ([ P lem] @ lem_opts @ [ A "-ocaml"; P (env "%.lem") ]));
(* XXX should be unnecessary with new lem
* mv (basename (env "%.ml")) (dirname (env "%.ml")) *)
]);
rule "sail -> lem"
~prod: "%.lem"
~deps: ["%.sail"; "main.native"]
(fun env builder -> Seq [
Cmd (S [ P "./main.native"; A "-lem_ast"; P (env "%.sail") ]);
mv (basename (env "%.lem")) (dirname (env "%.lem"))
]);
| _ -> ()
end ;;
|