package lsp
LSP protocol implementation in OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
jsonrpc-1.4.0.tbz
sha256=fd138e6c4fcff32c6d15eb66cc9391b7e1183717a6d1a47c688c7f6d320a159f
sha512=567a73b3c10bb59c5a4d4e8291d1aeefdfd34438a95313fba8a485638294ca5fb8034334719631243c304d3328c27afa90dfd564fdb1e7390507a06db3a4ad03
doc/src/lsp.fiber_unix/fiber_detached.ml.html
Source file fiber_detached.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
open Import open Fiber.O type mvar = | Done | Task of (unit -> unit Fiber.t) type status = | Open | Closed type t = { mvar : mvar Fiber.Mvar.t ; mutable status : status } let create () = { mvar = Fiber.Mvar.create (); status = Open } let task t ~f = match t.status with | Closed -> Fiber.return (Error `Stopped) | Open -> let+ () = Fiber.Mvar.write t.mvar (Task f) in Ok () let task_exn t ~f = let+ res = task t ~f in match res with | Ok () -> () | Error `Stopped -> Code_error.raise "detached already closed" [] let rec sequence t = let+ next = Fiber.Mvar.read t.mvar in match next with | Done -> Fiber.Sequence.Nil | Task task -> Cons (task, sequence t) let check_open t = if t.status = Closed then Code_error.raise "detached already closed" [] let stop t = check_open t; let+ () = Fiber.Mvar.write t.mvar Done in check_open t; t.status <- Closed let run t = sequence t |> Fiber.Sequence.parallel_iter ~f:(fun task -> task ())
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>