package vscoq-language-server
VSCoq language server
Install
Dune Dependency
Authors
Maintainers
Sources
vscoq-language-server-2.2.5.tar.gz
md5=8bc848aaf2ad0fe41a02741e633ad7e3
sha512=eb6c80a3290b1d688ea3b94a3087f204c9f9f03bddd95b21952b02af1dc4de073c1b99baed5a5f6a395e69a27c0d45f6ec181488da62e9f5c6a77d91d752dd5c
doc/vscoq-language-server.dm/Dm/Scheduler/index.html
Module Dm.Scheduler
Source
The scheduler is the component in charge of planning the execution of sentences. It also defines the task delegation strategy, and computes dependencies between tasks. Scheduling can be done incrementally.
State for incremental schedule construction
Source
type executable_sentence = {
id : Types.sentence_id;
ast : Synterp.vernac_control_entry;
classif : Vernacextend.vernac_classification;
synterp : Vernacstate.Synterp.t;
error_recovery : error_recovery_strategy;
}
Source
type task =
| Skip of {
id : Types.sentence_id;
error : Pp.t option;
}
| Block of {
id : Types.sentence_id;
error : Pp.t Loc.located;
}
| Exec of executable_sentence
| OpaqueProof of {
terminator : executable_sentence;
opener_id : Types.sentence_id;
proof_using : Vernacexpr.section_subset_expr;
tasks : executable_sentence list;
}
| Query of executable_sentence
Holds the dependencies among sentences and a schedule to evaluate all sentences
Source
val schedule_sentence :
(Types.sentence_id
* (Synterp.vernac_control_entry
* Vernacextend.vernac_classification
* Vernacstate.Synterp.t)) ->
state ->
schedule ->
state * schedule
Identifies the structure of the document and dependencies between sentences in order to easily compute the tasks to interpret the a sentence. Input sentence is None on parsing error.
Finds the task to be performed and the state on which the task should run
Computes what should be invalidated
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>