package coq-lsp
Language Server Protocol native server for Coq
Install
Dune Dependency
Authors
Maintainers
Sources
coq-lsp-0.1.4.v8.16.tbz
sha256=50df59eafc5b24a881c1a1dda6f6032b1da35b9b6ade7cb9e39968def9319508
sha512=e1d383b6802758cdbe5cbc6278af275d7951acd78224cdcfe622428942e84366ca283bf375d6e535ad7e8d8e847df84bd763bb2a263fc457dc5aead386c2836d
doc/src/coq-lsp.coq/parsing.ml.html
Source file parsing.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
let bp_ = ref 0 let undamage_jf loc = Loc. { loc with bol_pos = loc.bol_pos - !bp_ ; bp = loc.bp - !bp_ ; ep = loc.ep - !bp_ } let undamage_jf_opt loc = Option.map undamage_jf loc module PCoqHack = struct type t = { pa_tok_strm : Tok.t LStream.t ; lexer_state : CLexer.Lexer.State.t ref } let loc (p : Pcoq.Parsable.t) : Loc.t = let p : t = Obj.magic p in LStream.current_loc p.pa_tok_strm |> undamage_jf end module Parsable = struct include Pcoq.Parsable let loc = PCoqHack.loc end let parse ~st ps = let mode = State.mode ~st in let st = State.parsing ~st in (* Coq is missing this, so we add it here. Note that this MUST run inside coq_protect *) Control.check_for_interrupt (); Vernacstate.Parser.parse st Pvernac.(main_entry mode) ps |> Option.map (fun { CAst.loc; v } -> CAst.make ?loc:(undamage_jf_opt loc) v) |> Option.map Ast.of_coq let parse ~st ps = Protect.eval ~f:(parse ~st) ps (* Read the input stream until a dot or a "end of proof" token is encountered *) let parse_to_terminator : unit Pcoq.Entry.t = (* type 'a parser_fun = { parser_fun : te LStream.t -> 'a } *) let rec dot st = match LStream.next st with | Tok.KEYWORD ("." | "..." | "Qed" | "Defined" | "Admitted") | Tok.BULLET _ -> () | Tok.EOI -> () | _ -> dot st in Pcoq.Entry.of_parser "Coqtoplevel.dot" { parser_fun = dot } (* If an error occurred while parsing, we try to read the input until a dot token is encountered. We assume that when a lexer error occurs, at least one char was eaten *) let rec discard_to_dot ps = try Pcoq.Entry.parse parse_to_terminator ps with | CLexer.Error.E _ -> discard_to_dot ps | e when CErrors.noncritical e -> ()
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>