+;;
+
+(* compiler ala pascal/java using make *)
+let main_compiler () =
+ MatitaInit.initialize_all ();
+ (* targets and deps *)
+ let targets = Helm_registry.get_list Helm_registry.string "matita.args" in
+ let deps =
+ match targets with
+ | [] ->
+ (match Librarian.find_roots_in_dir (Sys.getcwd ()) with
+ | [x] ->
+ Make.load_deps_file (Filename.dirname x ^ "/depends")
+ | [] ->
+ HLog.error "No targets and no root found"; exit 1
+ | roots ->
+ HLog.error ("Too many roots found, move into one and retry: "^
+ String.concat ", " roots);exit 1);
+ | hd::_ ->
+ let root, _, _ = Librarian.baseuri_of_script hd in
+ Make.load_deps_file (root ^ "/depends")
+ in
+ (* must be called after init since args are set by cmdline parsing *)
+ let system_mode = Helm_registry.get_bool "matita.system" in
+ if system_mode then HLog.message "Compiling in system space";
+ if not (Helm_registry.get_bool "matita.verbose") then MatitaMisc.shutup ();
+ (* here we go *)
+ let module F =
+ struct
+ type source_object = string
+ type target_object = string
+ let string_of_source_object s = s;;
+ let string_of_target_object s = s;;
+
+ let target_of mafile =
+ let _,baseuri,_ = Librarian.baseuri_of_script mafile in
+ LibraryMisc.obj_file_of_baseuri
+ ~must_exist:false ~baseuri ~writable:true
+ ;;
+
+ let mtime_of_source_object s =
+ try Some (Unix.stat s).Unix.st_mtime
+ with Unix.Unix_error (Unix.ENOENT, "stat", f) when f = s ->
+ raise (Failure ("Unable to stat a source file: " ^ s))
+ ;;
+
+ let mtime_of_target_object s =
+ try Some (Unix.stat s).Unix.st_mtime
+ with Unix.Unix_error (Unix.ENOENT, "stat", f) when f = s -> None
+ ;;
+
+ let build fname =
+ let oldfname =
+ Helm_registry.get_opt
+ Helm_registry.string "matita.filename"
+ in
+ let rc = MatitacLib.compile fname in
+ (match oldfname with
+ | Some n -> Helm_registry.set_string "matita.filename" n;
+ | _ -> Helm_registry.unset "matita.filename");
+ rc
+ ;;
+ end
+ in
+ let module Make = Make.Make(F) in
+ Make.make deps targets
+;;
+