Saved context for postponed terms and tactics to be executed.
- options : Lean.Options
- openDecls : List Lean.OpenDecl
- macroStack : Lean.Elab.MacroStack
- errToSorry : Bool
Instances For
We use synthetic metavariables as placeholders for pending elaboration steps.
- typeClass: Option Lean.MessageData → Lean.Elab.Term.SyntheticMVarKind
Use typeclass resolution to synthesize value for metavariable. If
extraErrorMsg?issome msg,msgcontains additional information to include in error messages regarding type class synthesis failure. - coe: Option String → Lean.Expr → Lean.Expr → Option Lean.Expr → Lean.Elab.Term.SyntheticMVarKind
Use coercion to synthesize value for the metavariable. if
f?issome f, we produce an application type mismatch error message. Otherwise, ifheader?issome header, we generate the error(header ++ "has type" ++ eType ++ "but it is expected to have type" ++ expectedType)Otherwise, we generate the error("type mismatch" ++ e ++ "has type" ++ eType ++ "but it is expected to have type" ++ expectedType) - tactic: Lean.Syntax → Lean.Elab.Term.SavedContext → Lean.Elab.Term.SyntheticMVarKind
Use tactic to synthesize value for metavariable.
- postponed: Lean.Elab.Term.SavedContext → Lean.Elab.Term.SyntheticMVarKind
Metavariable represents a hole whose elaboration has been postponed.
Instances For
Equations
- Lean.Elab.Term.instInhabitedSyntheticMVarKind = { default := Lean.Elab.Term.SyntheticMVarKind.typeClass default }
Convert an "extra" optional error message into a message "\n{msg}" (if some msg) and MessageData.nil (if none)
Equations
- Lean.Elab.Term.extraMsgToMsg extraErrorMsg? = match extraErrorMsg? with | some msg => Lean.toMessageData "\n" ++ Lean.toMessageData msg ++ Lean.toMessageData "" | x => Lean.MessageData.nil
Instances For
Equations
- One or more equations did not get rendered due to their size.
- stx : Lean.Syntax
Instances For
Equations
- Lean.Elab.Term.instInhabitedSyntheticMVarDecl = { default := { stx := default, kind := default } }
We can optionally associate an error context with a metavariable (see MVarErrorInfo).
We have three different kinds of error context.
- implicitArg: Lean.Expr → Lean.Elab.Term.MVarErrorKind
Metavariable for implicit arguments.
ctxis the parent application. - hole: Lean.Elab.Term.MVarErrorKind
Metavariable for explicit holes provided by the user (e.g.,
_and?m) - custom: Lean.MessageData → Lean.Elab.Term.MVarErrorKind
"Custom",
msgDatastores the additional error messages.
Instances For
Equations
- Lean.Elab.Term.instInhabitedMVarErrorKind = { default := Lean.Elab.Term.MVarErrorKind.implicitArg default }
Equations
- One or more equations did not get rendered due to their size.
We can optionally associate an error context with metavariables.
- mvarId : Lean.MVarId
- ref : Lean.Syntax
- kind : Lean.Elab.Term.MVarErrorKind
Instances For
Equations
- Lean.Elab.Term.instInhabitedMVarErrorInfo = { default := { mvarId := default, ref := default, kind := default, argName? := default } }
Nested let rec expressions are eagerly lifted by the elaborator.
We store the information necessary for performing the lifting here.
- ref : Lean.Syntax
- fvarId : Lean.FVarId
- attrs : Array Lean.Elab.Attribute
- shortDeclName : Lake.Name
- declName : Lake.Name
- lctx : Lean.LocalContext
- localInstances : Lean.LocalInstances
- type : Lean.Expr
- val : Lean.Expr
- mvarId : Lean.MVarId
- termination : Lean.Elab.WF.TerminationHints
Instances For
Equations
- One or more equations did not get rendered due to their size.
State of the TermElabM monad.
- syntheticMVars : Lean.MVarIdMap Lean.Elab.Term.SyntheticMVarDecl
- pendingMVars : List Lean.MVarId
- mvarErrorInfos : Lean.MVarIdMap Lean.Elab.Term.MVarErrorInfo
- letRecsToLift : List Lean.Elab.Term.LetRecToLift
Instances For
Equations
- One or more equations did not get rendered due to their size.
Backtrackable state for the TermElabM monad.
- meta : Lean.Meta.SavedState
- elab : Lean.Elab.Term.State
Instances For
Equations
- Lean.Elab.Tactic.instInhabitedState = { default := { goals := default } }
Snapshots are used to implement the save tactic.
This tactic caches the state of the system, and allows us to "replay"
expensive proofs efficiently. This is only relevant implementing the
LSP server.
- core : Lean.Core.State
- meta : Lean.Meta.State
- term : Lean.Elab.Term.State
- tactic : Lean.Elab.Tactic.State
- stx : Lean.Syntax
Instances For
Key for the cache used to implement the save tactic.
- mvarId : Lean.MVarId
- pos : String.Pos
Instances For
Equations
Equations
- Lean.Elab.Tactic.instInhabitedCacheKey = { default := { mvarId := default, pos := default } }
Cache for the save tactic.
Instances For
Equations
- Lean.Elab.Tactic.instInhabitedCache = { default := { pre := default, post := default } }
- term : Lean.Elab.Term.SavedState
- tactic : Lean.Elab.Tactic.State
Instances For
State after finishing execution of a tactic.
- state? : Option Lean.Elab.Tactic.SavedState
Reusable state, if no fatal exception occurred.
Instances For
Equations
- Lean.Elab.Tactic.instInhabitedTacticFinished = { default := { state? := default } }
Snapshot just before execution of a tactic.
- diagnostics : Lean.Language.Snapshot.Diagnostics
- infoTree? : Option Lean.Elab.InfoTree
- isFatal : Bool
- stx : Lean.Syntax
Syntax tree of the tactic, stored and compared for incremental reuse.
- finished : Task Lean.Elab.Tactic.TacticFinished
Task for state after tactic execution.
Instances For
Equations
- Lean.Elab.Tactic.instInhabitedTacticParsedSnapshotData = { default := { toSnapshot := default, stx := default, finished := default } }
State after execution of a single synchronous tactic step.
- mk: Lean.Elab.Tactic.TacticParsedSnapshotData → Array (Lean.Language.SnapshotTask Lean.Elab.Tactic.TacticParsedSnapshot) → Lean.Elab.Tactic.TacticParsedSnapshot
Instances For
Equations
- Lean.Elab.Tactic.instInhabitedTacticParsedSnapshot = { default := Lean.Elab.Tactic.TacticParsedSnapshot.mk default default }
Equations
- x.data = match x with | Lean.Elab.Tactic.TacticParsedSnapshot.mk data next => data
Instances For
Potential, potentially parallel, follow-up tactic executions.
Equations
- x.next = match x with | Lean.Elab.Tactic.TacticParsedSnapshot.mk data next => next
Instances For
- auxDeclToFullName : Lean.FVarIdMap Lake.Name
Map
.auxDecllocal declarations used to encode recursive declarations to their full-names. - macroStack : Lean.Elab.MacroStack
- mayPostpone : Bool
When
mayPostpone == true, an elaboration function may interrupt its execution by throwingException.postpone. The functionelabTermcatches this exception and creates fresh synthetic metavariable?m, stores?min the list of pending synthetic metavariables, and returns?m. - errToSorry : Bool
When
errToSorryis set to true, the methodelabTermcatches exceptions and converts them into syntheticsorrys. The implementation of choice nodes and overloaded symbols rely on the fact that whenerrToSorryis set to false for an elaboration functionF, thenerrToSorryremainsfalsefor all elaboration functions invoked byF. That is, it is safe to transitionerrToSorryfromtruetofalse, but we must not seterrToSorrytotruewhen it is currently set tofalse. - autoBoundImplicit : Bool
When
autoBoundImplicitis set to true, instead of producing an "unknown identifier" error for unbound variables, we generate an internal exception. This exception is caught atelabBindersandelabTypeWithUnboldImplicit. Both methods add implicit declarations for the unbound variable and try again. - autoBoundImplicits : Lean.PArray Lean.Expr
A name
nis only eligible to be an auto implicit name ifautoBoundImplicitForbidden n = false. We use this predicate to disallowfto be considered an auto implicit name in a definition such asdef f : f → Bool := fun _ => true- sectionVars : Lake.NameMap Lake.Name
Map from user name to internal unique name
- sectionFVars : Lake.NameMap Lean.Expr
Map from internal name to fvar
- implicitLambda : Bool
Enable/disable implicit lambdas feature.
- heedElabAsElim : Bool
Heed
elab_as_elimattribute. - isNoncomputableSection : Bool
Noncomputable sections automatically add the
noncomputablemodifier to any declaration we cannot generate code for. - ignoreTCFailures : Bool
When
truewe skip TC failures. We use this option when processing patterns. - inPattern : Bool
truewhen elaborating patterns. It affects how we elaborate named holes. - tacticCache? : Option (IO.Ref Lean.Elab.Tactic.Cache)
Cache for the
savetactic. It is onlysomein the LSP server. Snapshot for incremental processing of current tactic, if any.
Invariant: if the bundle's
old?is set, then the state up to the start of the tactic is unchanged, i.e. reuse is possible.- saveRecAppSyntax : Bool
If
true, we store in theExprtheSyntaxfor recursive applications (i.e., applications of free variables tagged withisAuxDecl). We store theSyntaxusingmkRecAppWithSyntax. We use theSyntaxobject to produce better error messages atStructural.leanandWF.lean. - holesAsSyntheticOpaque : Bool
If
holesAsSyntheticOpaqueistrue, then we mark metavariables associated with_s assyntheticOpaqueif they do not occur in patterns. This option is useful when elaborating terms in tactics such asrefine'where we want holes there to become new goals. See issue #1681, we have `refine' (fun x => _)
Instances For
Equations
Instances For
Equations
Instances For
Equations
- Lean.Elab.Term.instMonadTermElabM = let i := inferInstanceAs (Monad Lean.Elab.TermElabM); Monad.mk
Equations
- Lean.Elab.Term.saveState = do let __do_lift ← liftM Lean.Meta.saveState let __do_lift_1 ← get pure { meta := __do_lift, elab := __do_lift_1 }
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Incremental reuse primitive: if reusableResult? is none, runs act and returns its result
together with the saved monadic state after act including the heartbeats used by it. If
reusableResult? on the other hand is some (a, state), restores full state including heartbeats
used and returns (a, state).
The intention is for steps that support incremental reuse to initially pass none as
reusableResult? and store the result and state in a snapshot. In a further run, if reuse is
possible, reusableResult? should be set to the previous result and state, ensuring that the state
after running withRestoreOrSaveFull is identical in both runs. Note however that necessarily this
is only an approximation in the case of heartbeats as heartbeats used by withRestoreOrSaveFull
itself after calling act as well as by reuse-handling code such as the one supplying
reusableResult? are not accounted for.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.instMonadBacktrackSavedStateTermElabM = { saveState := Lean.Elab.Term.saveState, restoreState := fun (b : Lean.Elab.Term.SavedState) => b.restore }
Manages reuse information for nested tactics by splitting given syntax into an outer and inner
part. act is then run on the inner part but with reuse information adjusted as following:
- If the old (from
tacSnap?'sSyntaxGuarded.stx) and new (fromstx) outer syntax are not identical according toSyntax.eqWithInfo, reuse is disabled. - Otherwise, the old syntax as stored in
tacSnap?is updated to the old inner syntax. - In any case, we also use
withRefon the inner syntax to avoid leakage of the outer syntax intoactvia this route.
For any tactic that participates in reuse, withNarrowedTacticReuse should be applied to the
tactic's syntax and act should be used to do recursive tactic evaluation of nested parts.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A variant of withNarrowedTacticReuse that uses stx[argIdx] as the inner syntax and all stx
child nodes before that as the outer syntax, i.e. reuse is disabled if there was any change before
argIdx.
NOTE: child nodes after argIdx are not tested (which would almost always disable reuse as they are
necessarily shifted by changes at argIdx) so it must be ensured that the result of arg does not
depend on them (i.e. they should not be inspected beforehand).
Equations
- One or more equations did not get rendered due to their size.
Instances For
Disables incremental tactic reuse and reporting for act if cond is true by setting tacSnap?
to none. This should be done for tactic blocks that are run multiple times as otherwise the
reported progress will jump back and forth (and partial reuse for these kinds of tact blocks is
similarly questionable).
Equations
- One or more equations did not get rendered due to their size.
Instances For
Disables incremental tactic reuse for act if cond is true.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Instances For
Execute x, save resulting expression and new state.
We remove any Info created by x.
The info nodes are committed when we execute applyResult.
We use observing to implement overloaded notation and decls.
We want to save Info nodes for the chosen alternative.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Apply the result/exception and state captured with observing.
We use this method to implement overloaded notation and symbols.
Equations
- Lean.Elab.Term.applyResult result = match result with | EStateM.Result.ok a r => do r.restore true pure a | EStateM.Result.error ex r => do r.restore true throw ex
Instances For
Execute x, but keep state modifications only if x did not postpone.
This method is useful to implement elaboration functions that cannot decide whether
they need to postpone or not without updating the state.
Equations
Instances For
Return the universe level names explicitly provided by the user.
Equations
- Lean.Elab.Term.getLevelNames = do let __do_lift ← get pure __do_lift.levelNames
Instances For
Given a free variable fvar, return its declaration.
This function panics if fvar is not a free variable.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Execute x without storing Syntax for recursive applications. See saveRecAppSyntax field at Context.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.mkTermElabAttributeUnsafe ref = Lean.Elab.mkElabAttribute Lean.Elab.Term.TermElab `builtin_term_elab `term_elab `Lean.Parser.Term `Lean.Elab.Term.TermElab "term" ref
Instances For
Auxiliary datatype for presenting a Lean lvalue modifier.
We represent an unelaborated lvalue as a Syntax (or Expr) and List LVal.
Example: a.foo.1 is represented as the Syntax a and the list
[LVal.fieldName "foo", LVal.fieldIdx 1].
- fieldIdx: Lean.Syntax → Nat → Lean.Elab.Term.LVal
- fieldName: Lean.Syntax → String → Option Lake.Name → Lean.Syntax → Lean.Elab.Term.LVal
Field
suffix?is for producing better error messages becausex.ymay be a field access or a hierarchical/composite name.refis the syntax object representing the field.fullRefincludes the LHS.
Instances For
Equations
- x.getRef = match x with | Lean.Elab.Term.LVal.fieldIdx ref i => ref | Lean.Elab.Term.LVal.fieldName ref name suffix? fullRef => ref
Instances For
Equations
- x.isFieldName = match x with | Lean.Elab.Term.LVal.fieldName ref name suffix? fullRef => true | x => false
Instances For
Equations
- One or more equations did not get rendered due to their size.
Return the name of the declaration being elaborated if available.
Equations
- Lean.Elab.Term.getDeclName? = do let __do_lift ← read pure __do_lift.declName?
Instances For
Return the list of nested let rec declarations that need to be lifted.
Equations
- Lean.Elab.Term.getLetRecsToLift = do let __do_lift ← get pure __do_lift.letRecsToLift
Instances For
Return the declaration of the given metavariable
Equations
- Lean.Elab.Term.getMVarDecl mvarId = do let __do_lift ← Lean.getMCtx pure (__do_lift.getDecl mvarId)
Instances For
Equations
- Lean.Elab.Term.instMonadParentDeclTermElabM = { getParentDeclName? := Lean.Elab.Term.getDeclName? }
Execute withSaveParentDeclInfoContext x with declName? := name. See getDeclName?.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Update the universe level parameter names.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Execute x using levelNames as the universe level parameter names. See getLevelNames.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Declare an auxiliary local declaration shortDeclName : type for elaborating recursive declaration declName,
update the mapping auxDeclToFullName, and then execute k.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Execute x without converting errors (i.e., exceptions) to sorry applications.
Recall that when errToSorry = true, the method elabTerm catches exceptions and converts them into sorry applications.
Equations
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Execute x without heeding the elab_as_elim attribute. Useful when there is
no expected type (so elabAppArgs would fail), but expect that the user wants
to use such constants.
Equations
Instances For
Execute x but discard changes performed at Term.State and Meta.State.
Recall that the Environment and InfoState are at Core.State. Thus, any updates to it will
be preserved. This method is useful for performing computations where all
metavariable must be resolved or discarded.
The InfoTrees are not discarded, however, and wrapped in InfoTree.Context
to store their metavariable context.
Equations
- Lean.Elab.Term.withoutModifyingElabMetaStateWithInfo x = do let s ← get let sMeta ← getThe Lean.Meta.State tryFinally (Lean.Elab.withSaveInfoContext x) do set s set sMeta
Instances For
For testing TermElabM methods. The #eval command will sign the error.
Equations
- Lean.Elab.Term.throwErrorIfErrors = do let __do_lift ← Lean.MonadLog.hasErrors if __do_lift = true then Lean.throwError (Lean.toMessageData "Error(s)") else pure PUnit.unit
Instances For
Equations
- Lean.Elab.Term.traceAtCmdPos cls msg = Lean.withRef Lean.Syntax.missing (Lean.trace cls msg)
Instances For
Equations
- Lean.Elab.Term.ppGoal mvarId = liftM (Lean.Meta.ppGoal mvarId)
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Instances For
Elaborate x with stx on the macro stack
Equations
- One or more equations did not get rendered due to their size.
Instances For
Elaborate x with stx on the macro stack and produce macro expansion info
Equations
- Lean.Elab.Term.withMacroExpansion beforeStx afterStx x = Lean.Elab.withMacroExpansionInfo beforeStx afterStx (Lean.Elab.Term.withPushMacroExpansionStack beforeStx afterStx x)
Instances For
Add the given metavariable to the list of pending synthetic metavariables.
The method synthesizeSyntheticMVars is used to process the metavariables on this list.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.registerSyntheticMVarWithCurrRef mvarId kind = do let __do_lift ← Lean.getRef Lean.Elab.Term.registerSyntheticMVar __do_lift mvarId kind
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.registerMVarErrorHoleInfo mvarId ref = Lean.Elab.Term.registerMVarErrorInfo { mvarId := mvarId, ref := ref, kind := Lean.Elab.Term.MVarErrorKind.hole, argName? := none }
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.getMVarErrorInfo? mvarId = do let __do_lift ← get pure (Lean.RBMap.find? __do_lift.mvarErrorInfos mvarId)
Instances For
Equations
- Lean.Elab.Term.registerCustomErrorIfMVar e ref msgData = match e.getAppFn with | Lean.Expr.mvar mvarId => Lean.Elab.Term.registerMVarErrorCustomInfo mvarId ref msgData | x => pure ()
Instances For
Auxiliary method for reporting errors of the form "... contains metavariables ...".
This kind of error is thrown, for example, at Match.lean where elaboration
cannot continue if there are metavariables in patterns.
We only want to log it if we haven't logged any errors so far.
Equations
- Lean.Elab.Term.throwMVarError m = do let __do_lift ← Lean.MonadLog.hasErrors if __do_lift = true then Lean.Elab.throwAbortTerm else Lean.throwError m
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Append mvarErrorInfo argument name (if available) to the message.
Remark: if the argument name contains macro scopes we do not append it.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.MVarErrorInfo.logError.appendExtra extraMsg? msg = match extraMsg? with | none => msg | some extraMsg => msg ++ extraMsg
Instances For
Try to log errors for the unassigned metavariables pendingMVarIds.
Return true if there were "unfilled holes", and we should "abort" declaration.
TODO: try to fill "all" holes using synthetic "sorry's"
Remark: We only log the "unfilled holes" as new errors if no error has been logged so far.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Ensure metavariables registered using registerMVarErrorInfos (and used in the given declaration) have been assigned.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Execute x without allowing it to postpone elaboration tasks.
That is, tryPostpone is a noop.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Creates syntax for ( <ident> : <type> )
Equations
- One or more equations did not get rendered due to their size.
Instances For
Convert unassigned universe level metavariables into parameters.
The new parameter names are fresh names of the form u_i with regard to ctx.levelNames, which is updated with the new names.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Auxiliary method for creating fresh binder names. Do not confuse with the method for creating fresh free/meta variable ids.
Equations
- Lean.Elab.Term.mkFreshBinderName = Lean.withFreshMacroScope (Lean.MonadQuotation.addMacroScope `x)
Instances For
Auxiliary method for creating a Syntax.ident containing
a fresh name. This method is intended for creating fresh binder names.
It is just a thin layer on top of mkFreshUserName.
Equations
- Lean.Elab.Term.mkFreshIdent ref canonical = do let __do_lift ← Lean.Elab.Term.mkFreshBinderName pure (Lean.mkIdentFrom ref __do_lift canonical)
Instances For
Apply given attributes at a given application time
Equations
- Lean.Elab.Term.applyAttributesAt declName attrs applicationTime = Lean.Elab.Term.applyAttributesCore declName attrs (some applicationTime)
Instances For
Equations
- Lean.Elab.Term.applyAttributes declName attrs = Lean.Elab.Term.applyAttributesCore declName attrs none
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Instances For
See containsPostponedTerm
Return true if e contains a pending metavariable. Remark: it also visits let-declarations.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Try to synthesize metavariable using type class resolution.
This method assumes the local context and local instances of instMVar coincide
with the current local context and local instances.
Return true if the instance was synthesized successfully, and false if
the instance contains unassigned metavariables that are blocking the type class
resolution procedure. Throw an exception if resolution or assignment irrevocably fails.
If extraErrorMsg? is not none, it contains additional information that should be attached
to type class synthesis failures.
Equations
- One or more equations did not get rendered due to their size.
Instances For
If expectedType? is some t, then ensures t and eType are definitionally equal by inserting a coercion if necessary.
Argument f? is used only for generating error messages when inserting coercions fails.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Log the given exception, and create a synthetic sorry for representing the failed
elaboration step with exception ex.
Equations
- Lean.Elab.Term.exceptionToSorry ex expectedType? = do let syntheticSorry ← Lean.Elab.Term.mkSyntheticSorryFor expectedType? Lean.Elab.logException ex pure syntheticSorry
Instances For
If mayPostpone == true, throw Expection.postpone.
Equations
- Lean.Elab.Term.tryPostpone = do let __do_lift ← read if __do_lift.mayPostpone = true then Lean.Elab.throwPostpone else pure PUnit.unit
Instances For
Return true if e reduces (by unfolding only [reducible] declarations) to ?m ...
Equations
- Lean.Elab.Term.isMVarApp e = do let __do_lift ← liftM (Lean.Meta.whnfR e) pure __do_lift.getAppFn.isMVar
Instances For
If mayPostpone == true and e's head is a metavariable, throw Exception.postpone.
Equations
- Lean.Elab.Term.tryPostponeIfMVar e = do let __do_lift ← Lean.Elab.Term.isMVarApp e if __do_lift = true then Lean.Elab.Term.tryPostpone else pure PUnit.unit
Instances For
If e? = some e, then tryPostponeIfMVar e, otherwise it is just tryPostpone.
Equations
- Lean.Elab.Term.tryPostponeIfNoneOrMVar e? = match e? with | some e => Lean.Elab.Term.tryPostponeIfMVar e | none => Lean.Elab.Term.tryPostpone
Instances For
Throws Exception.postpone, if expectedType? contains unassigned metavariables.
It is a noop if mayPostpone == false.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Throws Exception.postpone, if expectedType? contains unassigned metavariables.
If mayPostpone == false, it throws error msg.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Save relevant context for term elaboration postponement.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Execute x with the context saved using saveContext.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.getSyntheticMVarDecl? mvarId = do let __do_lift ← get pure (Lean.RBMap.find? __do_lift.syntheticMVars mvarId)
Instances For
Create an auxiliary annotation to make sure we create an Info even if e is a metavariable.
See mkTermInfo.
We use this function because some elaboration functions elaborate subterms that may not be immediately part of the resulting term. Example:
let_mvar% ?m := b; wait_if_type_mvar% ?m; body
If the type of b is not known, then wait_if_type_mvar% ?m; body is postponed and just returns a fresh
metavariable ?n. The elaborator for
let_mvar% ?m := b; wait_if_type_mvar% ?m; body
returns mkSaveInfoAnnotation ?n to make sure the info nodes created when elaborating b are "saved".
This is a bit hackish, but elaborators like let_mvar% are rare.
Equations
- Lean.Elab.Term.mkSaveInfoAnnotation e = if e.isMVar = true then Lean.mkAnnotation `save_info e else e
Instances For
Equations
- Lean.Elab.Term.isSaveInfoAnnotation? e = Lean.annotation? `save_info e
Instances For
Return some mvarId if e corresponds to a hole that is going to be filled "later" by executing a tactic or resuming elaboration.
We do not save ofTermInfo for this kind of node in the InfoTree.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Pushes a new leaf node to the info tree associating the expression e to the syntax stx.
As a result, when the user hovers over stx they will see the type of e, and if e
is a constant they will see the constant's doc string.
expectedType?: the expected type ofeat the point of elaboration, if availablelctx?: the local context in which to interprete(otherwise it will use← getLCtx)elaborator: a declaration name used as an alternative target for go-to-definitionisBinder: if true, this will be treated as defininge(which should be a local constant) for the purpose of go-to-definition on local variablesforce: In patterns, the effect ofaddTermInfois usually suppressed and replaced by apatternWithRef?annotation which will be turned into a term info on the post-match-elaboration expression. This flag overrides that behavior and adds the term info immediately. (See https://github.com/leanprover/lean4/pull/1664.)
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.addTermInfo' stx e expectedType? lctx? elaborator isBinder = discard (Lean.Elab.Term.addTermInfo stx e expectedType? lctx? elaborator isBinder)
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Postpone the elaboration of stx, return a metavariable that acts as a placeholder, and
ensures the info tree is updated and a hole id is introduced.
When stx is elaborated, new info nodes are created and attached to the new hole id in the info tree.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- Lean.Elab.Term.hasNoImplicitLambdaAnnotation type = (Lean.annotation? `noImplicitLambda type).isSome
Instances For
Equations
- Lean.Elab.Term.mkNoImplicitLambdaAnnotation type = if Lean.Elab.Term.hasNoImplicitLambdaAnnotation type = true then type else Lean.mkAnnotation `noImplicitLambda type
Instances For
Block usage of implicit lambdas if stx is @f or @f arg1 ... or fun with an implicit binder annotation.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Return true iff stx is a Syntax.ident, and it is a local variable.
Equations
- One or more equations did not get rendered due to their size.
Instances For
- no: Lean.Elab.Term.UseImplicitLambdaResult
- yes: Lean.Expr → Lean.Elab.Term.UseImplicitLambdaResult
- postpone: Lean.Elab.Term.UseImplicitLambdaResult
Instances For
Store in the InfoTree that e is a "dot"-completion target. stx should cover the entire term.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Main function for elaborating terms.
It extracts the elaboration methods from the environment using the node kind.
Recall that the environment has a mapping from SyntaxNodeKind to TermElab methods.
It creates a fresh macro scope for executing the elaboration method.
All unlogged trace messages produced by the elaboration method are logged using
the position information at stx. If the elaboration method throws an Exception.error and errToSorry == true,
the error is logged and a synthetic sorry expression is returned.
If the elaboration throws Exception.postpone and catchExPostpone == true,
a new synthetic metavariable of kind SyntheticMVarKind.postponed is created, registered,
and returned.
The option catchExPostpone == false is used to implement resumeElabTerm
to prevent the creation of another synthetic metavariable when resuming the elaboration.
If implicitLambda == false, then disable implicit lambdas feature for the given syntax, but not for its subterms.
We use this flag to implement, for example, the @ modifier. If Context.implicitLambda == false, then this parameter has no effect.
Equations
- Lean.Elab.Term.elabTerm stx expectedType? catchExPostpone implicitLambda = Lean.withRef stx (Lean.Elab.Term.elabTermAux expectedType? catchExPostpone implicitLambda stx)
Instances For
Similar to Lean.Elab.Term.elabTerm, but ensures that the type of the elaborated term is expectedType?
by inserting coercions if necessary.
If errToSorry is true, then if coercion insertion fails, this function returns sorry and logs the error.
Otherwise, it throws the error.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Execute x and return some if no new errors were recorded or exceptions were thrown. Otherwise, return none.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Adapt a syntax transformation to a regular, term-producing elaborator.
Equations
- Lean.Elab.Term.adaptExpander exp stx expectedType? = do let stx' ← exp stx Lean.Elab.Term.withMacroExpansion stx stx' (Lean.Elab.Term.elabTerm stx' expectedType? true)
Instances For
Create a new metavariable with the given type, and try to synthesize it.
If type class resolution cannot be executed (e.g., it is stuck because of metavariables in type),
register metavariable as a pending one.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Make sure e is a type by inferring its type and making sure it is an Expr.sort
or is unifiable with Expr.sort, or can be coerced into one.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Elaborate stx and ensure result is a type.
Equations
- Lean.Elab.Term.elabType stx = do let u ← liftM Lean.Meta.mkFreshLevelMVar let type ← Lean.Elab.Term.elabTerm stx (some (Lean.mkSort u)) true Lean.withRef stx (Lean.Elab.Term.ensureType type)
Instances For
Enable auto-bound implicits, and execute k while catching auto bound implicit exceptions. When an exception is caught,
a new local declaration is created, registered, and k is tried to be executed again.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Collect unassigned metavariables in type that are not already in init and not satisfying except.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Return autoBoundImplicits ++ xs
This method throws an error if a variable in autoBoundImplicits depends on some x in xs.
The autoBoundImplicits may contain free variables created by the auto-implicit feature, and unassigned free variables.
It avoids the hack used at autoBoundImplicitsOld.
Remark: we cannot simply replace every occurrence of addAutoBoundImplicitsOld with this one because a particular
use-case may not be able to handle the metavariables in the array being given to k.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Similar to autoBoundImplicits, but immediately if the resulting array of expressions contains metavariables,
it immediately uses mkForallFVars + forallBoundedTelescope to convert them into free variables.
The type type is modified during the process if type depends on xs.
We use this method to simplify the conversion of code using autoBoundImplicitsOld to autoBoundImplicits.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Return true if mvarId is an auxiliary metavariable created for compiling let rec or it
is delayed assigned to one.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Create an Expr.const using the given name and explicit levels.
Remark: fresh universe metavariables are created if the constant has more universe
parameters than explicitLevels.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Similar to resolveName, but creates identifiers for the main part and each projection with position information derived from ident.
Example: Assume resolveName v.head.bla.boo produces (v.head, ["bla", "boo"]), then this method produces
(v.head, id, [f₁, f₂]) where id is an identifier for v.head, and f₁ and f₂ are identifiers for fields "bla" and "boo".
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- x.run ctx s = Lean.Meta.withConfig Lean.Elab.Term.setElabConfig ((x ctx).run s)
Instances For
Equations
- x.run' ctx s = (fun (x : α × Lean.Elab.Term.State) => x.fst) <$> x.run ctx s
Instances For
Equations
Instances For
Equations
- One or more equations did not get rendered due to their size.
Execute x and then tries to solve pending universe constraints.
Note that, stuck constraints will not be discarded.
Equations
- Lean.Elab.Term.universeConstraintsCheckpoint x = do let a ← x discard (liftM (Lean.Meta.processPostponed true true)) pure a
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Helper function for "embedding" an Expr in Syntax.
It creates a named hole ?m and immediately assigns e to it.
Examples:
let e := mkConst ``Nat.zero
`(Nat.succ $(← exprToSyntax e))
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.addBuiltinIncrementalElab decl = ST.Ref.modify Lean.Elab.builtinIncrementalElabs fun (s : Lean.NameSet) => s.insert decl
Instances For
Checks whether a declaration is annotated with [builtin_incremental] or [incremental].
Equations
- One or more equations did not get rendered due to their size.