package eio
Effect-based direct-style IO API for OCaml
Install
dune-project
Dependency
Authors
Maintainers
Sources
eio-1.3.tbz
sha256=8ed5c13e6689f31c85dca5f12762d84b8cc0042a7b07d3e464df6eb4b72b3dfc
sha512=46e8f817f32c3316e7f35835a136ad177a295b3306351eb2efa2386482b0169a5b19ed2925b32da2a1f10d40f083fe3d588dd401908f9fec6e4a44cd68535204
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 51
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 = Trace.with_span "traceln" @@ fun () -> 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)"
>