MessageLog with interactive diagnostics.
Can be created using Diagnostics.empty or Diagnostics.ofMessageLog.
- msgLog : MessageLogNon-interactive message log. 
- Dynamic mutable slot usable by the language server for memorizing interactive diagnostics. If - none, interactive diagnostics are not remembered, which should only be used for messages not containing any interactive elements as client-side state will be lost on recreating a diagnostic.- See also section "Communication" in Lean/Server/README.md. 
Instances For
Equations
Instances For
The empty set of diagnostics.
Equations
- Lean.Language.Snapshot.Diagnostics.empty = { msgLog := Lean.MessageLog.empty, interactiveDiagsRef? := none }
Instances For
The base class of all snapshots: all the generic information the language server needs about a snapshot.
- desc : StringDebug description shown by trace.Elab.snapshotTree, defaults to the caller's decl name.
- diagnostics : DiagnosticsThe messages produced by this step. The union of message logs of all finished snapshots is reported to the user. 
- infoTree? : Option Elab.InfoTreeGeneral elaboration metadata produced by this step. 
- traces : TraceStateTrace data produced by this step. Currently used only by trace.profiler.output, otherwise we depend on the elaborator adding traces todiagnosticseventually.
- isFatal : BoolWhether it should be indicated to the user that a fatal error (which should be part of diagnostics) occurred that prevents processing of the remainder of the file.
Instances For
Equations
Range that is marked as being processed by the server while a task is running.
- inherit : ReportingRangeInherit range from outer task if any, or else the entire file. 
- some
(range : String.Range)
 : ReportingRangeUse given range. 
- skip : ReportingRangeDo not mark as being processed. Child nodes are still visited. 
Instances For
Constructs a reporting range by replacing a missing range with inherit, which is a reasonable
default to ensure that a range is shown in all cases.
Equations
Instances For
Yields the default reporting range of a Syntax, which is just the canonicalOnly range
of the syntax if any, or inherit otherwise.
Equations
Instances For
A task producing some snapshot type (usually a subclass of Snapshot).
- Syntaxprocessed by this- SnapshotTask. The- Syntaxis used by the language server to determine whether to force this- SnapshotTaskwhen a request is made. In general, the elaborator retains the following invariant: If- stx?is- none, then this snapshot task (and all of its children) do not contain- InfoTreeinformation that can be used in the language server, and so the language server will ignore it when it is looking for an- InfoTree. Nonetheless, if- stx?is- none, then this snapshot task (and any of its children) may still contain message log information.
- reportingRange : ReportingRangeRange that is marked as being processed by the server while the task is running. 
- cancelTk? : Option IO.CancelTokenCancellation token that can be set by the server to cancel the task when it detects the results are not needed anymore. 
- task : Task αUnderlying task producing the snapshot. 
Instances For
Equations
Instances For
Equations
Creates a snapshot task from the syntax processed by the task and a BaseIO action.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Creates a finished snapshot task.
Equations
- Lean.Language.SnapshotTask.finished stx? a = { stx? := stx?, reportingRange := Lean.Language.SnapshotTask.ReportingRange.skip, cancelTk? := none, task := { get := a } }
Instances For
Transforms a task's output without changing the processed syntax.
Equations
Instances For
Chains two snapshot tasks. The processed syntax and the reporting range are taken from the first task if not specified; the processed syntax and the reporting range of the second task are discarded. The cancellation tokens of both tasks are discarded. They are replaced with the given token if any.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Synchronously waits on the result of the task.
Instances For
Arbitrary value paired with a syntax that should be inspected when considering the value for reuse.
- stx : SyntaxSyntax to be inspected for reuse. 
- val : αPotentially reusable value. 
Instances For
Pair of (optional) old snapshot task usable for incremental reuse and new snapshot promise for
incremental reporting. Inside the elaborator, we build snapshots by carrying such bundles and then
checking if we can reuse old? if set or else redoing the corresponding elaboration step. In either
case, we derive new bundles for nested snapshots, if any, and finally resolve new to the result.
Note that failing to resolve a created promise will block the language server indefinitely!
We use withAlwaysResolvedPromise/withAlwaysResolvedPromises to ensure this doesn't happen.
In the future, the 1-element history old? may be replaced with a global cache indexed by strong
hashes but the promise will still need to be passed through the elaborator.
- old? : Option (SyntaxGuarded (SnapshotTask α))Snapshot task of corresponding elaboration in previous document version if any, paired with its old syntax to be considered for reuse. Should be set to noneas soon as reuse can be ruled out.
- new : IO.Promise αPromise of snapshot value for the current document. When resolved, the language server will report its result even before the current elaborator invocation has finished. 
Instances For
Tree of snapshots where each snapshot comes with an array of asynchronous further subtrees. Used
for asynchronously collecting information about the entirety of snapshots in the language server.
The involved tasks may form a DAG on the Task dependency level but this is not captured by this
data structure.
- element : SnapshotThe immediately available element of the snapshot tree node. 
- children : Array (SnapshotTask SnapshotTree)The asynchronously available children of the snapshot tree node. 
Instances For
Equations
Instances For
Helper class for projecting a heterogeneous hierarchy of snapshot classes to a homogeneous representation.
- toSnapshotTree : α → SnapshotTreeTransforms a language-specific snapshot to a homogeneous snapshot tree. 
Instances
Equations
- Lean.Language.instToSnapshotTreeSnapshotTree = { toSnapshotTree := fun (s : Lean.Language.SnapshotTree) => s }
Equations
- Lean.Language.instToSnapshotTreeOption = { toSnapshotTree := fun (x : Option α) => match x with | some a => Lean.Language.toSnapshotTree a | none => default }
Recursively triggers all SnapshotTask.cancelTk? in the reachable tree, asynchronously.
Snapshot type without child nodes.
Instances For
Equations
- Lean.Language.instInhabitedSnapshotLeaf.default = { toSnapshot := default }
Instances For
Equations
- Lean.Language.instToSnapshotTreeSnapshotLeaf = { toSnapshotTree := fun (s : Lean.Language.SnapshotLeaf) => { element := s.toSnapshot, children := #[] } }
Arbitrary snapshot type, used for extensibility.
- val : DynamicConcrete snapshot value as Dynamic.
- tree : Thunk SnapshotTreeSnapshot tree retrieved from valbefore erasure. We do thunk even the first level as accessing it too early can create some unnecessary tasks fromtoSnapshotTreethat are otherwise avoided by(sync := true)when accessing only after elaboration has finished. Early access can even lead to deadlocks when later forcing these unnecessary tasks on a starved thread pool.
Instances For
Equations
- Lean.Language.instToSnapshotTreeDynamicSnapshot = { toSnapshotTree := fun (s : Lean.Language.DynamicSnapshot) => s.tree.get }
Creates a DynamicSnapshot from a typed snapshot value.
Equations
- Lean.Language.DynamicSnapshot.ofTyped val = { val := Dynamic.mk val, tree := { fn := fun (x : Unit) => Lean.Language.toSnapshotTree val } }
Instances For
Returns the original snapshot value if it is of the given type.
Equations
- Lean.Language.DynamicSnapshot.toTyped? α snap = Dynamic.get? α snap.val
Instances For
Equations
- One or more equations did not get rendered due to their size.
Runs a tree of snapshots to conclusion, incrementally performing f on each snapshot in tree
preorder.
Runs a tree of snapshots to conclusion,
folding the function f over each snapshot in tree preorder.
Option for printing end position of each message in addition to start position. Used for testing message ranges in the test suite.
Runs a tree of snapshots to conclusion and incrementally report messages on stdout. Messages are
reported in tree preorder. Returns whether any errors were reported.
This function is used by the cmdline driver; see Lean.Server.FileWorker.reportSnapshots for how
the language server reports snapshots asynchronously.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Waits on and returns all snapshots in the tree.
Equations
Instances For
Returns a task that waits on all snapshots in the tree.
Equations
Instances For
Context of an input processing invocation.
Instances For
Monad transformer holding all relevant data for processing.
Equations
Instances For
Monad holding all relevant data for processing.
Instances For
Equations
- Lean.Language.instMonadLiftProcessingMProcessingTIO = { monadLift := fun {α : Type} (act : Lean.Language.ProcessingM α) (ctx : Lean.Language.ProcessingContext) => liftM (act ctx) }
Creates snapshot message log from non-interactive message log, also allocating a mutable cell that can be used by the server to memorize interactive diagnostics derived from the log.
Equations
Instances For
Creates diagnostics from a single error message that should span the whole file.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Adds unexpected exceptions from header processing to the message log as a last resort; standard errors should already have been caught earlier.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Builds a function for processing a language using incremental snapshots by passing the previous
snapshot to Language.process on subsequent invocations.
Equations
- One or more equations did not get rendered due to their size.