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
47
let run_and_time_call ~use f =
let start = Unix.gettimeofday () in
let result = f () in
let stop = Unix.gettimeofday () in
use (stop -. start);
result
let query_log_path : Fpath.t option =
let env_var = "QUERY_LOG_PATH" in
match Bos.OS.Env.var env_var with Some p -> Some (Fpath.v p) | None -> None
let[@inline never] protect m f =
Mutex.lock m;
match f () with
| x ->
Mutex.unlock m;
x
| exception e ->
Mutex.unlock m;
let bt = Printexc.get_raw_backtrace () in
Printexc.raise_with_backtrace e bt
let write =
match query_log_path with
| None -> fun _ _ -> ()
| Some path ->
let log_entries : (Expr.t list * int64) list ref = ref [] in
let close () =
let entries = List.rev !log_entries in
let bytes = Marshal.to_string entries [] in
match Bos.OS.File.write path bytes with
| Ok () -> ()
| Error (`Msg e) -> Fmt.failwith "Failed to write log: %s" e
in
at_exit close;
Sys.set_signal Sys.sigterm (Sys.Signal_handle (fun _ -> close ()));
let mutex = Mutex.create () in
fun assumptions time ->
let entry = (assumptions, time) in
protect mutex (fun () -> log_entries := entry :: !log_entries)