Documentation

Lean.Elab.InfoTree.Main

Merges the inner partial context into the outer context s.t. fields of the inner context overwrite fields of the outer context. Panics if the invariant described in the documentation for PartialContextInfo is violated.

When traversing an InfoTree, this function should be used to combine the context of outer nodes with the partial context of their subtrees. This ensures that the traversal has the context from the inner node to the root node of the InfoTree available, with partial contexts of inner nodes taking priority over contexts of outer nodes.

Instances For

    Obtains the LocalContext from this CompletionInfo if available and yields an empty context otherwise.

    Instances For

      Instantiate the holes on the given tree with the assignment table. (analogous to instantiating the metavariables in an expression)

      Applies s.lazyAssignment to s.trees, asynchronously.

      Instances For
        def Lean.Elab.ContextInfo.runCoreM {α : Type} (info : ContextInfo) (x : CoreM α) :
        IO α

        Embeds a CoreM action in IO by supplying the information stored in info.

        Instances For
          def Lean.Elab.ContextInfo.runMetaM {α : Type} (info : ContextInfo) (lctx : LocalContext) (x : MetaM α) :
          IO α
          Instances For
            Instances For
              def Lean.Elab.TermInfo.runMetaM {α : Type} (info : TermInfo) (ctx : ContextInfo) (x : MetaM α) :
              IO α
              Instances For
                Instances For
                  Instances For
                    Instances For

                      Helper function for propagating the tactic metavariable context to its children nodes. We need this function because we preserve TacticInfo nodes during backtracking and their children. Moreover, we backtrack the metavariable context to undo metavariable assignments. TacticInfo nodes save the metavariable context before/after the tactic application, and can be pretty printed without any extra information. This is not the case for TermInfo nodes. Without this function, the formatting method would often fail when processing TermInfo nodes that are children of TacticInfo nodes that have been preserved during backtracking. Saving the metavariable context at TermInfo nodes is also not a good option because at TermInfo creation time, the metavariable context often miss information, e.g., a TC problem has not been resolved, a postponed subterm has not been elaborated, etc.

                      See Term.SavedState.restore.

                      Instances For

                        Returns the current array of InfoTrees and resets it to an empty array.

                        Instances For
                          Instances For
                            Instances For
                              Instances For
                                def Lean.Elab.addConstInfo {m : TypeType} [Monad m] [MonadInfoTree m] [MonadEnv m] [MonadError m] (stx : Syntax) (n : Name) (expectedType? : Option Expr := none) :
                                Instances For

                                  This does the same job as realizeGlobalConstNoOverload; resolving an identifier syntax to a unique fully resolved name or throwing if there are ambiguities. But also adds this resolved name to the infotree. This means that when you hover over a name in the source file you will see the fully resolved name in the hover info.

                                  Instances For

                                    Similar to realizeGlobalConstNoOverloadWithInfo, except if there are multiple name resolutions then it returns them as a list.

                                    Instances For

                                      Similar to realizeGlobalName, but it also adds the resolved name to the info tree.

                                      Instances For
                                        def Lean.Elab.withInfoContext' {m : TypeType} [Monad m] [MonadInfoTree m] {α : Type} [MonadFinally m] (x : m α) (mkInfo : αm (Info MVarId)) (mkInfoOnError : m Info) :
                                        m α

                                        Adds a node containing the InfoTrees generated by x to the InfoTrees in m.

                                        If x succeeds and mkInfo yields an Info, the InfoTrees of x become subtrees of a node containing the Info produced by mkInfo, which is then added to the InfoTrees in m. If x succeeds and mkInfo yields an MVarId, the InfoTrees of x are discarded and a hole node is added to the InfoTrees in m. If x fails, the InfoTrees of x become subtrees of a node containing the Info produced by mkInfoOnError, which is then added to the InfoTrees in m.

                                        The InfoTrees in m are reset before x is executed and restored with the addition of a new tree after x is executed.

                                        Instances For
                                          def Lean.Elab.withInfoTreeContext {m : TypeType} [Monad m] [MonadInfoTree m] {α : Type} [MonadFinally m] (x : m α) (mkInfoTree : PersistentArray InfoTreem InfoTree) :
                                          m α

                                          Saves the current list of trees t₀, runs x to produce a new tree list t₁ and runs mkInfoTree t₁ to get n : InfoTree and then restores the trees to be t₀ ++ [n].

                                          Instances For
                                            @[inline]
                                            def Lean.Elab.withInfoContext {m : TypeType} [Monad m] [MonadInfoTree m] {α : Type} [MonadFinally m] (x : m α) (mkInfo : m Info) :
                                            m α

                                            Run x as a new child infotree node with header given by mkInfo.

                                            Instances For

                                              Resets the trees state t₀, runs x to produce a new trees state t₁ and sets the state to be t₀ ++ (InfoTree.context (PartialContextInfo.commandCtx Γ) <$> t₁) where Γ is the context derived from the monad state.

                                              Instances For

                                                Resets the trees state t₀, runs x to produce a new trees state t₁ and sets the state to be t₀ ++ (InfoTree.context (PartialContextInfo.parentDeclCtx Γ) <$> t₁) where Γ is the parent decl name provided by MonadParentDecl m.

                                                Instances For

                                                  Resets the trees state t₀, runs x to produce a new trees state t₁ and sets the state to be t₀ ++ (InfoTree.context (PartialContextInfo.autoImplicitCtx Γ) <$> t₁) where Γ is the set of auto-implicits provided by MonadAutoImplicits m.

                                                  Instances For
                                                    Instances For
                                                      def Lean.Elab.assignInfoHoleId {m : TypeType} [Monad m] [MonadInfoTree m] (mvarId : MVarId) (infoTree : InfoTree) :
                                                      Instances For
                                                        def Lean.Elab.withMacroExpansionInfo {m : TypeType} {α : Type} [MonadFinally m] [Monad m] [MonadInfoTree m] [MonadLCtx m] (stx output : Syntax) (x : m α) :
                                                        m α
                                                        Instances For
                                                          @[inline]
                                                          def Lean.Elab.withInfoHole {m : TypeType} {α : Type} [MonadFinally m] [Monad m] [MonadInfoTree m] (mvarId : MVarId) (x : m α) :
                                                          m α

                                                          Runs x. The last info tree that is pushed while running x is assigned to mvarId. All other pushed info trees are silently discarded.

                                                          Instances For
                                                            def Lean.Elab.enableInfoTree {m : TypeType} [MonadInfoTree m] (flag : Bool := true) :
                                                            Instances For
                                                              def Lean.Elab.withEnableInfoTree {m : TypeType} {α : Type} [Monad m] [MonadInfoTree m] [MonadFinally m] (flag : Bool) (x : m α) :
                                                              m α
                                                              Instances For