package eio
Effect-based direct-style IO API for OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
eio-1.0.tbz
sha256=da260d9da38b3dde9f316652a20b13a261cf90b85a2498ac669b7d564e61942d
sha512=5886e1159f48ede237769baa1d8b5daafa0310e4192d7fe0e8c32aef70f2b6378cef72d0fbae308457e25d87a69802b9ee83a5e8f23e0591d83086a92d701c46
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)"
>