package lsp
LSP protocol implementation in OCaml
Install
Dune Dependency
Authors
-
AAndrey Popp <8mayday@gmail.com>
-
RRusty Key <iam@stfoo.ru>
-
LLouis Roché <louis@louisroche.net>
-
OOleksiy Golovko <alexei.golovko@gmail.com>
-
RRudi Grinberg <me@rgrinberg.com>
-
SSacha Ayoun <sachaayoun@gmail.com>
-
Ccannorin <cannorin@gmail.com>
-
UUlugbek Abdullaev <ulugbekna@gmail.com>
-
Thibaut Mattio
-
MMax Lantas <mnxndev@outlook.com>
Maintainers
Sources
jsonrpc-1.10.3.tbz
sha256=a3ac1073b0728b94f4bdb0111772c0abaf7ff70324399450eab7156bfac151f1
sha512=bed6ddbde28088e43db0d40ab27056ba22537d19ffe8117a3da4c77676948f18708b06937dd2c972dce5c5822ea751c9c85cfa1ce3c1b3739460d4a24ebc2282
doc/src/lsp.stdune/top_closure.ml.html
Source file top_closure.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
# 1 "submodules/dune/otherlibs/stdune/top_closure.ml" module Make (Keys : Top_closure_intf.Keys) (Monad : Monad_intf.S) = struct open Monad.O let top_closure ~key ~deps elements = let rec loop res visited elt ~temporarily_marked = let key = key elt in if Keys.mem temporarily_marked key then Monad.return (Error [ elt ]) else if not (Keys.mem visited key) then let visited = Keys.add visited key in let temporarily_marked = Keys.add temporarily_marked key in deps elt >>= iter_elts res visited ~temporarily_marked >>= function | Error l -> Monad.return (Error (elt :: l)) | Ok (res, visited) -> let res = elt :: res in Monad.return (Ok (res, visited)) else Monad.return (Ok (res, visited)) and iter_elts res visited elts ~temporarily_marked = Monad.return elts >>= function | [] -> Monad.return (Ok (res, visited)) | elt :: elts -> ( loop res visited elt ~temporarily_marked >>= function | Error _ as result -> Monad.return result | Ok (res, visited) -> iter_elts res visited elts ~temporarily_marked) in iter_elts [] Keys.empty elements ~temporarily_marked:Keys.empty >>= function | Ok (res, _visited) -> Monad.return (Ok (List.rev res)) | Error elts -> Monad.return (Error elts) end [@@inlined always] module Int = Make (Int.Set) (Monad.Id) module String = Make (String.Set) (Monad.Id)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>