-open Ocamlbuild_plugin
-open Command
+open Ocamlbuild_plugin ;;
-let includes = Hashtbl.create 17
-let register_include dir =
- if not (Hashtbl.mem includes dir) then begin
- Hashtbl.add includes dir ();
- dep [ "extension:ml" ]
- (List.map (fun s -> dir ^ "/" ^ s )
- (Array.to_list (Pathname.readdir dir)))
- end
+let includes = [ "include/utils.ml"; "include/utils32.ml"; "include/utils64.ml"; "include/debug.ml" ]
-let macro_flags = [
- "macro_include",
- (fun s -> register_include s; S [A"-ppopt"; A "-I"; A"-ppopt"; A s]);
- "macro_define", (fun s -> S [A"-ppopt"; A ("-D"^s)]);
-]
+let ml_str_rule () =
+ rule ".ml.str" ~dep:"%.ml.str" ~prod:"%.ml"
+ (fun env _ ->
+ let mlstr = env "%.ml.str" and ml = env "%.ml" in
+ let cmd = Printf.sprintf "echo -n 'let content = \"' > %s ;\
+ sed -e 's/\\([\"\\\\]\\)/\\\\\\1/g' %s | sed -e 's/^\\(.*\\)$/\\1\\\\n\\\\/g' >> %s ;\
+ echo '' >> %s ;\
+ echo '\"' >> %s" ml mlstr ml ml ml
+ in
+ Cmd ( Sh cmd ))
+
+let () =
+ dispatch begin function
+ | After_rules ->
+ dep ["ocaml";"compile";] includes;
+ dep ["ocaml";"ocamldep"; ] includes;
+ pflag ["ocaml";"compile";] "ppopt" (fun s -> S [A"-ppopt"; A (s)]);
+ pflag ["ocaml";"ocamldep";] "ppopt" (fun s -> S [A"-ppopt"; A (s)]);
+ ml_str_rule ()
+ | _ -> ()
-let () = dispatch begin
- function
- | Before_rules ->
- List.iter (fun s ->
- List.iter (fun (fl, fu) ->
- pflag s fl fu) macro_flags
- )
- [["ocaml";"compile"];
- ["ocaml";"ocamldep"] ]
-;
- | _ -> ()
-end
+end;;