Skip to content

Commit

Permalink
driver.mld: Optionally instrument with landmarks
Browse files Browse the repository at this point in the history
The results are stored in `_build/default/doc/landmarks` with unique
names.

Co-authored-by: Paul-Elliot <[email protected]>
  • Loading branch information
Julow and panglesd committed Sep 12, 2023
1 parent 7522361 commit 3c24db4
Showing 1 changed file with 20 additions and 1 deletion.
21 changes: 20 additions & 1 deletion doc/driver.mld
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ let (>>=) = Result.bind;;
let (>>|=) m f = m >>= fun x -> Ok (f x);;
let get_ok = function | Ok x -> x | Error (`Msg m) -> failwith m
let relativize p = Fpath.(v ".." // p) (* this driver is run from the [doc] dir *)

(* Whether to instrument with landmarks. Result for each commands will be saved
to directory [_build/default/doc/landmarks]. *)
let instrument = false
]}

{1 Desired Output}
Expand Down Expand Up @@ -165,9 +169,24 @@ type executed_command = {
the produced file. *)
let commands = ref [ ]

(* Environment variables passed to commands. *)
let env =
let env = OS.Env.current () |> get_ok in
let env =
if instrument then (
let instrument_dir = Fpath.v "landmarks" in
OS.Dir.delete instrument_dir |> get_ok;
OS.Dir.create instrument_dir |> get_ok |> ignore;
Astring.String.Map.add "OCAML_LANDMARKS"
("time,allocation,format=json,output=temporary:" ^ Fpath.to_string instrument_dir)
env
) else env
in
env

let run ?output_file cmd =
let t_start = Unix.gettimeofday () in
let r = OS.Cmd.(run_out ~err:OS.Cmd.err_run_out cmd |> to_lines) |> get_ok in
let r = OS.Cmd.(run_out ~env ~err:OS.Cmd.err_run_out cmd |> to_lines) |> get_ok in
let t_end = Unix.gettimeofday () in
let time = t_end -. t_start in
commands := { cmd; time; output_file } :: !commands;
Expand Down

0 comments on commit 3c24db4

Please sign in to comment.