Documentation

Lean.Elab.InfoTree.Types

Context after executing liftTermElabM. Note that the term information collected during elaboration may contain metavariables, and their assignments are stored at mctx.

Instances For

    Context from the root of the InfoTree up to this node. Note that the term information collected during elaboration may contain metavariables, and their assignments are stored at mctx.

    Instances For

      Context for a sub-InfoTree.

      Within InfoTree, this must fulfill the invariant that every non-commandCtx PartialContextInfo node is always contained within a commandCtx node.

      Instances For

        Base structure for TermInfo, CommandInfo and TacticInfo.

        • elaborator : Lean.Name

          The name of the elaborator that created this info.

        • The piece of syntax that the elaborator created this info for. Note that this also implicitly stores the code position in the syntax's SourceInfo.

        Instances For
          Equations

          Used instead of TermInfo when a term couldn't successfully be elaborated, and so there is no complete expression available.

          The main purpose of PartialTermInfo is to ensure that the sub-InfoTrees of a failed elaborator are retained so that they can still be used in the language server.

          Instances For

            A completion is an item that appears in the IntelliSense box that appears as you type.

            Instances For

              Info for an option reference (e.g. in set_option).

              Instances For
                Instances For
                  Equations

                  The information needed to render the tactic state in the infoview.

                  We store the list of goals before and after the execution of a tactic. We also store the metavariable context at each time since we want metavariables unassigned at tactic execution time to be displayed as ?m....

                  Instances For
                    Equations

                    Dynamic info for custom use cases.

                    Instances For

                      Information about a user widget associated with a syntactic span. This must be a panel widget. A panel widget is a widget that can be displayed in the infoview alongside the goal state.

                      Instances For

                        Specifies that the given free variables should be considered semantically identical. The free variable baseId might not be in the current local context because it has been cleared. Used for e.g. connecting variables before and after match generalization.

                        Instances For

                          Contains the syntax of an identifier which is part of a field redeclaration, like:

                          structure Foo := x : Nat
                          structure Bar extends Foo :=
                            x := 0
                          --^ here
                          
                          Instances For

                            Denotes TermInfo with additional configurations to control interactions with delaborated terms.

                            For example, the omission term that is emitted by the delaborator when omitting a term due to pp.deepTerms false or pp.proofs false uses this. Omission needs to be treated differently from regular terms because it has to be delaborated differently in Lean.Widget.InteractiveDiagnostics.infoToInteractive: Regular terms are delaborated explicitly, whereas omitted terms are simply to be expanded with regular delaboration settings. Additionally, omissions come with a reason for omission.

                            Instances For

                              Indicates that all overloaded elaborators failed. The subtrees of a ChoiceInfo node are the partial InfoTrees of those failed elaborators. Retaining these partial InfoTrees helps the language server provide interactivity even when all overloaded elaborators failed.

                              Instances For
                                inductive Lean.Elab.Info :

                                Header information for a node in InfoTree.

                                Instances For

                                  The InfoTree is a structure that is generated during elaboration and used by the language server to look up information about objects at particular points in the Lean document. For example, tactic information and expected type information in the infoview and information about completions.

                                  The infotree consists of nodes which may have child nodes. Each node has an Info object that contains details about what kind of information is present. Each Info object also contains a Syntax instance, this is used to map positions in the Lean document to particular info objects.

                                  An example of a function that extracts information from an infotree for a given position is InfoTree.goalsAt? which finds TacticInfo.

                                  Information concerning expressions requires that a context also be saved. context nodes store a local context that is used to process expressions in nodes below.

                                  Because the info tree is generated during elaboration, some parts of the infotree for a particular piece of syntax may not be ready yet. Hence InfoTree supports metavariable-like holes which are filled in later in the same way that unassigned metavariables are.

                                  Instances For

                                    This structure is the state that is being used to build an InfoTree object. During elaboration, some parts of the info tree may be holes which need to be filled later. The assignments field is used to assign these holes. The trees field is a list of pending child trees for the infotree node currently being built.

                                    You should not need to use InfoState directly, instead infotrees should be built with the help of the methods here such as pushInfoLeaf to create leaf nodes and withInfoContext to create a nested child node.

                                    To see how trees is used, look at the function body of withInfoContext'.

                                    Instances For
                                      Equations
                                      Instances
                                        Equations
                                        • One or more equations did not get rendered due to their size.
                                        Instances