package vscoq-language-server
VSCoq language server
Install
Dune Dependency
Authors
Maintainers
Sources
vscoq-language-server-2.2.1.tar.gz
md5=06737aa7d96bbf42f89db3c86ef3e4dd
sha512=5118f26e5b687bc918de3409870464702f3fafc0c775ad5fac4835fc7954df66beaf83bc3a413476176160773215aae1d292816c49dc192c94566bba0fbe5a5b
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;
}
| 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)"
>