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
module CallBack = struct
type t =
{ trace : string -> ?extra:string -> string -> unit
; send_diagnostics :
ofmt:Format.formatter
-> uri:Lang.LUri.File.t
-> version:int
-> Lang.Diagnostic.t list
-> unit
; send_fileProgress :
ofmt:Format.formatter
-> uri:Lang.LUri.File.t
-> version:int
-> Progress.Info.t list
-> unit
}
let default =
{ trace = (fun _ ?extra:_ _ -> ())
; send_diagnostics = (fun ~ofmt:_ ~uri:_ ~version:_ _ -> ())
; send_fileProgress = (fun ~ofmt:_ ~uri:_ ~version:_ _ -> ())
}
let cb = ref default
let set t = cb := t
end
module Log = struct
let trace d ? m = !CallBack.cb.trace d ?extra m
let feedback feedback =
if not (CList.is_empty feedback) then
let = None in
!CallBack.cb.trace "feedback" ?extra
"feedback received in non-user facing place"
end
module Report = struct
let diagnostics ~ofmt ~uri ~version d =
!CallBack.cb.send_diagnostics ~ofmt ~uri ~version d
let fileProgress ~ofmt ~uri ~version d =
!CallBack.cb.send_fileProgress ~ofmt ~uri ~version d
end