Elaborator framework for (mutual) inductives #
This module defines the framework for elaborating (mutually recursive) inductive types.
Commands such as inductive
and structure
plug into this framework,
and the framework orchestrates their mutual elaboration.
The main entry point for new inductive commands are the @[builtin_inductive_elab]
/@[inductive_elab]
attributes,
which register a handler for a given decl syntax.
The main entry point to elaboration are the functions
Lean.Elab.Command.isInductiveCommand
to determine whether syntax has a registered inductive elaborator.Lean.Elab.Command.elabInductives
to elaborate a list of syntaxes as mutually inductive types.Lean.Elab.Command.elabInductive
to elaborate a single inductive command.
For mutual ... end
in particular:
Lean.Elab.Command.isMutualInductive
to check whether each syntax element of amutual ... end
block has a registered inductive elaborator.Lean.Elab.Command.elabMutualInductive
to elaborate a list of syntaxes satisfyingisMutualInductive
as a mutually inductive block.
See the docstring on Lean.Elab.Command.InductiveElabDescr
for an overview of the framework.
View of a constructor. Only ref
, modifiers
, declName
, and declId
are required by the mutual inductive elaborator itself.
- ref : Lean.Syntax
Syntax for the whole constructor.
- modifiers : Lean.Elab.Modifiers
- declName : Lean.Name
Fully qualified name of the constructor.
- declId : Lean.Syntax
Syntax for the name of the constructor, used to apply terminfo. If the source is synthetic, terminfo is not applied.
- binders : Lean.Syntax
For handler use. The
inductive
uses it for the binders to the constructor. - type? : Option Lean.Syntax
For handler use. The
inductive
command uses it for the resulting type for the constructor.
Instances For
Equations
- Lean.Elab.Command.instInhabitedCtorView = { default := { ref := default, modifiers := default, declName := default, declId := default, binders := default, type? := default } }
- ref : Lean.Syntax
- modifiers : Lean.Syntax
- fieldId : Lean.Name
- type : Lean.Term
- matchAlts : Lean.TSyntax `Lean.Parser.Term.matchAlts
Instances For
A view for generic inductive types.
- ref : Lean.Syntax
- declId : Lean.Syntax
- modifiers : Lean.Elab.Modifiers
- isClass : Bool
- allowIndices : Bool
Whether the command should allow indices (like
inductive
) or not (likestructure
). - allowSortPolymorphism : Bool
Whether the command supports creating inductive types that can be polymorphic across both
Prop
andType _
. If false, then either the universe must beProp
or it must be of the formType _
. - shortDeclName : Lean.Name
- declName : Lean.Name
- binders : Lean.Syntax
- type? : Option Lean.Syntax
- ctors : Array Lean.Elab.Command.CtorView
- computedFields : Array Lean.Elab.Command.ComputedFieldView
- derivingClasses : Array Lean.Elab.DerivingClassView
Instances For
Equations
- One or more equations did not get rendered due to their size.
Elaborated header for an inductive type before fvars for each inductive are added to the local context.
- lctx : Lean.LocalContext
- localInsts : Lean.LocalInstances
- type : Lean.Expr
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- Lean.Elab.Command.instInhabitedElabHeaderResult = { default := { toPreElabHeaderResult := default, indFVar := default } }
An intermediate step for mutual inductive elaboration. See InductiveElabDescr
.
- ctors : List Lean.Constructor
The constructors produced by
InductiveElabStep1
. - collectUsedFVars : StateRefT' IO.RealWorld Lean.CollectFVars.State Lean.MetaM Unit
Function to collect additional fvars that might be missed by the constructors. It is permissible to include fvars that do not exist in the local context (
structure
for example includes its field fvars). - checkUniverses : Nat → Lean.Level → Lean.Elab.TermElabM Unit
Function to check universes and provide a custom error. (
structure
uses this to do checks per field to give nicer messages.) - finalizeTermElab : Lean.Elab.TermElabM Unit
Step to finalize term elaboration, done immediately after universe level processing is complete.
- prefinalize : List Lean.Name → Array Lean.Expr → (Lean.Expr → Lean.MetaM Lean.Expr) → Lean.Elab.TermElabM Unit
Like
finalize
, but occurs beforeafterTypeChecking
attributes. - finalize : List Lean.Name → Array Lean.Expr → (Lean.Expr → Lean.MetaM Lean.Expr) → Lean.Elab.TermElabM Unit
Finalize the inductive type, after they are all added to the environment, after auxiliary definitions are added, and after computed fields are registered.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- Lean.Elab.Command.instInhabitedInductiveElabStep1 = { default := { view := default, elabCtors := default } }
Descriptor for a command processor that elaborates an inductive type.
Elaboration occurs in the following steps:
- Every command has its
mkInductiveView
evaluated, producingInductiveView
s and callbacks for the next steps (all recorded inInductiveElabStep1
). - Each
InductiveView
gets elaborated, creatingElabHeaderResult
s, and the local contexts are unified into a single one with a consistent set of parameters between each inductive. - Each callback is called to elaborate each inductives' constructors and some additional callbacks
(all recorded in
InductiveElabStep2
). - Fvars are collected from the constructors and from the
InductiveStep2.collectUsedFVars
callbacks. This is used to compute the final set of scoped variables that should be used as additional parameters. - Universe levels are checked. Commands can give custom errors using
InductiveStep2.collectUniverses
. - Elaboration of constructors is finalized, with additional tasks done by each
InductiveStep2.collectUniverses
. - The inductive family is added to the environment and is checked by the kernel.
- Attributes and other finalization activities are performed, including those defined
by
InductiveStep2.prefinalize
andInductiveStep2.finalize
.
- mkInductiveView : Lean.Elab.Modifiers → Lean.Syntax → Lean.Elab.TermElabM Lean.Elab.Command.InductiveElabStep1
Instances For
Equations
- Lean.Elab.Command.instInhabitedInductiveElabDescr = { default := { mkInductiveView := default } }
Environment extension to register inductive type elaborator commands.
Returns true if the syntax partipates in the mutual inductive elaborator.
These do not need to be commands. In fact inductive
and structure
are registered
on the Lean.Parser.Command.inductive
and Lean.Parser.Command.structure
syntaxes.
Equations
- Lean.Elab.Command.isInductiveCommand stx = do let env ← Lean.getEnv pure !(Lean.Elab.Command.inductiveElabAttr.getEntries env stx.getKind).isEmpty
Instances For
Initializes the elaborator associated to the given syntax.
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
Execute k
with updated binder information for xs
. Any x
that is explicit becomes implicit.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Returns some ?m
if u
is of the form ?m + k
.
Returns none if u
does not contain universe metavariables.
Throw exception otherwise.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Auxiliary function for updateResultingUniverse
.
Consider the constraint u ≤ ?r + rOffset
where u
has no metavariables except for perhaps ?r
.
This function attempts to find a unique minimal solution of the form ?r := max l₁ ... lₙ
where each lᵢ
is normalized and not a max
/imax
.
It also records information about how "too big" rOffset
is. Consider u ≤ ?r + 1
, from for example
inductive I (α : Sort u) : Type _ where
| mk (x : α)
This is likely a mistake. The correct solution would be Type (max u 1)
rather than Type (u + 1)
,
but by this point it is impossible to rectify. So, for u ≤ ?r + 1
we record the pair of u
and 1
so that we can inform the user what they should have probably used instead.
Equations
- Lean.Elab.Command.accLevel u r rOffset = Lean.Elab.Command.accLevel.go r u rOffset
Instances For
Equations
- One or more equations did not get rendered due to their size.
- Lean.Elab.Command.accLevel.go r (u_2.max v) rOffset = do Lean.Elab.Command.accLevel.go r u_2 rOffset Lean.Elab.Command.accLevel.go r v rOffset
- Lean.Elab.Command.accLevel.go r (u_2.imax v) rOffset = do Lean.Elab.Command.accLevel.go r u_2 rOffset Lean.Elab.Command.accLevel.go r v rOffset
- Lean.Elab.Command.accLevel.go r Lean.Level.zero rOffset = pure ()
- Lean.Elab.Command.accLevel.go r u_2.succ rOffset_2.succ = Lean.Elab.Command.accLevel.go r u_2 rOffset_2
Instances For
Auxiliary function for updateResultingUniverse
. Applies accLevel
to the given constructor parameter.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Executes k
using the Syntax
reference associated with constructor ctorName
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Runs k
with the resulting type as the ref or, if that's not available, with the view's ref.
Equations
- view.withTypeRef k = Lean.withRef view.ref (match view.type? with | some type => Lean.withRef type k | none => k)
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.Command.elabInductive modifiers stx = Lean.Elab.Command.elabInductives #[(modifiers, stx)]
Instances For
Returns true if all elements of the mutual
block (Lean.Parser.Command.mutual
) are inductive declarations.
Equations
- Lean.Elab.Command.isMutualInductive stx = Array.allM (fun (elem : Lean.Syntax) => Lean.Elab.Command.isInductiveCommand elem[1]) stx[1].getArgs
Instances For
Elaborates a mutual
block, assuming the commands satisfy Lean.Elab.Command.isMutualInductive
.
Equations
- One or more equations did not get rendered due to their size.