-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcustom_transformer.ml
72 lines (64 loc) · 1.7 KB
/
custom_transformer.ml
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
(** Use [Nloge.make_emit_handler] to create custom transformer
INFO:
message = "a"
label = "File \"examples/custom_transformer.ml\", line 34, characters 26-33"
index = 1
DEBUG:
message = "hello, 1"
index = 1
INFO:
message = "a"
label = "File \"examples/custom_transformer.ml\", line 34, characters 26-33"
index = 2
DEBUG:
message = "hello, 2"
index = 2
INFO:
message = "a"
label = "File \"examples/custom_transformer.ml\", line 34, characters 26-33"
index = 3
DEBUG:
message = "hello, 3"
index = 3
......
*)
let plain_transformer f =
Nloge.make_emit_handler f
@@ fun now level loc metadata msg ->
let json = Nloge.Trans.insert_info now level loc msg metadata in
let len = List.length json in
let k0 = Format.kasprintf (Nloge.write level) "%a:\n%s" Nloge.Level.pp level in
let k, _ =
ListLabels.fold_left json ~init:(k0, 0) ~f:(fun (k, idx) (label, v) ->
let idx' = idx + 1 in
let comma = if idx' = len then "" else "\n" in
( Format.kasprintf
k
"\t%-10s = %a%s%s"
label
(Yojson.Safe.pretty_print ~std:true)
v
comma
, idx' ))
in
k "\n"
;;
let () =
Eio_main.run
@@ fun env ->
Eio.Switch.run
@@ fun sw ->
Nloge.run
~clock:env#clock
~sw
~outputs:[ env#stdout ]
~level:`Debug
~trans:plain_transformer
@@ fun () ->
let index i = "index", `Int i in
for i = 1 to 200 do
let metadata = [ index i ] in
Nloge.info ~metadata ~__LOC__ (fun m -> m "a");
Nloge.debug ~metadata (fun m -> m "hello, %d" i)
done
;;