package coq-lsp
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=667908bdd88f0bb1b75d2fa76a483006d600c9422a2a15297a172e62c0415cad
sha512=42f8e5ad308702f77c9dc40243acd2e656b16bdb94c302306dbb87387cc36941deccd5f52c18d1a045467030ddf86528b22819522a647eee5b9e1ac25f4a9560
doc/coq-lsp.fleche/Fleche/Doc/index.html
Module Fleche.DocSource
Enviroment external to the document, this includes for now the init Coq state and the workspace, which are used to build the first state of the document, usually by importing the prelude and other libs implicitly.
type t = private {uri : Lang.LUri.File.t;(*
*)uriof the documentlanguageId : string;(*
*)languageIdof the documentversion : int;(*
*)versionof the documentcontents : Contents.t;(*
*)contentsof the documentnodes : Node.t list;(*List of document nodes
*)completed : Completion.t;(*Status of the document, usually either completed, suspended, or waiting for some IO / external event
*)toc : Node.t CString.Map.t;(*table of contents
*)env : Env.t;(*External document enviroment
*)root : Coq.State.t;(*
*)rootcontains the first state document state, obtained by applying a workspace to Coq's initial statediags_dirty : bool;(*internal field
*)
}A Flèche document is basically a node list, which is a crude form of a meta-data map Range.t -> data, where for now data is the contents of Node.t.
Return the list of all asts in the doc
Return the list of all diags in the doc
val create :
token:Coq.Limits.Token.t ->
env:Env.t ->
uri:Lang.LUri.File.t ->
languageId:string ->
version:int ->
raw:string ->
tCreate a new Coq document, this is cached! Note that this operation always suceeds, but the document could be created in a `Failed` state if problems arise.
Update the contents of a document, updating the right structures for incremental checking. If the operation fails, the document will be left in `Failed` state.
val check :
io:Io.CallBack.t ->
token:Coq.Limits.Token.t ->
target:Target.t ->
doc:t ->
unit ->
tcheck ~io ~target ~doc (), check document doc, target will have Flèche stop after the point specified there has been reached. Output functions are in the io record, used to send partial updates.
save ~doc will save doc .vo file. It will fail if proofs are open, or if the document completion status is not Yes
val run :
token:Coq.Limits.Token.t ->
?loc:Loc.t ->
?memo:bool ->
st:Coq.State.t ->
string ->
(Coq.State.t, Loc.t) Coq.Protect.E.trun ~token ?loc ?memo ~st cmds run commands cmds starting on state st, without commiting changes to the document. loc can be used to seed an initial location if desired, if not the locations will be considered relative to the initial location. memo controls if the execution is memoized, by default true.
This API is experimental, used for speculative execution petanque and goals, the API is expected to change as to better adapt to users.