package coq-lsp
Language Server Protocol native server for Coq
Install
Dune Dependency
Authors
Maintainers
Sources
coq-lsp-0.2.2.8.20.tbz
sha256=5404b94fbfe8c126470e7ef706001a77da6f6c388c314b6a80981c265a712399
sha512=1cc67ed0e0f0d5f64dc6e89239045f59e1ec85535496182ff6b7988621ff13e9fdd5e74e30224e37f3832a77435d1f636b15e46cd93e382b1c4256e96e9297c8
doc/src/coq-lsp.fleche/io.ml.html
Source file io.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 52 53 54 55 56 57 58 59 60 61 62 63 64
module Level = struct type t = | Error | Warning | Info | Log | Debug end module CallBack = struct type t = { trace : string -> ?extra:string -> string -> unit ; message : lvl:Level.t -> message:string -> unit ; diagnostics : uri:Lang.LUri.File.t -> version:int -> Lang.Diagnostic.t list -> unit ; fileProgress : uri:Lang.LUri.File.t -> version:int -> Progress.Info.t list -> unit ; perfData : uri:Lang.LUri.File.t -> version:int -> Perf.t -> unit ; serverVersion : ServerInfo.Version.t -> unit ; serverStatus : ServerInfo.Status.t -> unit } let default = { trace = (fun _ ?extra:_ _ -> ()) ; message = (fun ~lvl:_ ~message:_ -> ()) ; diagnostics = (fun ~uri:_ ~version:_ _ -> ()) ; fileProgress = (fun ~uri:_ ~version:_ _ -> ()) ; perfData = (fun ~uri:_ ~version:_ _ -> ()) ; serverVersion = (fun _ -> ()) ; serverStatus = (fun _ -> ()) } let cb = ref default let set t = cb := t end module Log = struct let trace_ d ?extra m = !CallBack.cb.trace d ?extra m let trace d ?extra = Format.kasprintf (fun m -> trace_ d ?extra m) let trace_object hdr obj = (* Fixme, use the extra parameter *) trace hdr "[%s]: @[%a@]" hdr Yojson.Safe.(pretty_print ~std:false) obj let feedback feedback = if not (CList.is_empty feedback) then (* Put feedbacks content here? *) let extra = None in !CallBack.cb.trace "feedback" ?extra "feedback received in non-user facing place" end module Report = struct let message_ ~io ~lvl ~message = io.CallBack.message ~lvl ~message let msg ~io ~lvl = Format.kasprintf (fun m -> message_ ~io ~lvl ~message:m) let diagnostics ~io ~uri ~version d = io.CallBack.diagnostics ~uri ~version d let fileProgress ~io ~uri ~version d = io.CallBack.fileProgress ~uri ~version d let perfData ~io ~uri ~version pd = io.CallBack.perfData ~uri ~version pd let serverVersion ~io vi = io.CallBack.serverVersion vi let serverStatus ~io st = io.CallBack.serverStatus st end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>