package eio
Effect-based direct-style IO API for OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
eio-0.14.tbz
sha256=52f85b947d3e0de70940b5bbaac0d3e78841fea5648e73af7d8a754ab51c871b
sha512=944095b1131d2dcc1f0d415fe46fd78b883733e0f95985e3a0feafe73b1703606ec60560abf36c16c364cc60164b7330f236e39569e264c702bb5647e28bfd3c
doc/src/eio.core/debug.ml.html
Source file debug.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
type traceln = { traceln : 'a. ?__POS__:string * int * int * int -> ('a, Format.formatter, unit, unit) format4 -> 'a; } [@@unboxed] let traceln_key : traceln Fiber.key = Fiber.create_key () let traceln_mutex = Mutex.create () let default_traceln ?__POS__:pos fmt = let k go = let b = Buffer.create 512 in let f = Format.formatter_of_buffer b in go f; Option.iter (fun (file, lnum, _, _) -> Format.fprintf f " [%s:%d]" file lnum) pos; Format.pp_close_box f (); Format.pp_print_flush f (); let msg = Buffer.contents b in Trace.log msg; let lines = String.split_on_char '\n' msg in Mutex.lock traceln_mutex; Fun.protect ~finally:(fun () -> Mutex.unlock traceln_mutex) @@ fun () -> List.iter (Printf.eprintf "+%s\n") lines; flush stderr in Format.kdprintf k ("@[" ^^ fmt) let get () = match Fiber.get traceln_key with | Some traceln -> traceln | None | exception (Effect.Unhandled _) -> { traceln = default_traceln } let with_trace_prefix prefix fn = let { traceln } = get () in let traceln ?__POS__ fmt = traceln ?__POS__ ("%t" ^^ fmt) prefix in Fiber.with_binding traceln_key { traceln } fn let traceln ?__POS__ fmt = let { traceln } = get () in traceln ?__POS__ fmt type t = < traceln : traceln Fiber.key; > let v = object method traceln = traceln_key end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>