Instructs the elaborator to elaborate applications of the given declaration without an expected type. This may prevent the elaborator from incorrectly inferring implicit arguments.
Equations
- Lean.Elab.Term.hasElabWithoutExpectedType env declName = Lean.Elab.Term.elabWithoutExpectedTypeAttr.hasTag env declName
Instances For
Equations
- One or more equations did not get rendered due to their size.
Erase entry for binderName from namedArgs.
Equations
- Lean.Elab.Term.eraseNamedArg namedArgs binderName = List.filter (fun (x : Lean.Elab.Term.NamedArg) => x.name != binderName) namedArgs
Instances For
Default application elaborator #
- ellipsis : Booltrueif..was used
- explicit : Booltrueif@modifier was used
- resultIsOutParamSupport : BoolIf the result type of an application is the outParamof some local instance, then special support may be needed because type class resolution interacts poorly with coercions in this kind of situation. This flag enables the special support.The idea is quite simple, if the result type is the outParamof some local instance, we simply executesynthesizeSyntheticMVarsUsingDefault. We added this feature to make sure examples as follows are correctly elaborated.class GetElem (Cont : Type u) (Idx : Type v) (Elem : outParam (Type w)) where getElem (xs : Cont) (i : Idx) : Elem export GetElem (getElem) instance : GetElem (Array α) Nat α where getElem xs i := xs.get ⟨i, sorry⟩ opaque f : Option Bool → Bool opaque g : Bool → Bool def bad (xs : Array Bool) : Bool := let x := getElem xs 0 f x && g xWithout the special support, Lean fails at g xsayingxhas typeOption Boolbut is expected to have typeBool. From the user's point of view this is a bug, sincelet x := getElem xs 0clearly constrainsxto beBool, but we only obtain this information after we apply theOfNatdefault instance for0.Before converging to this solution, we have tried to create a "coercion placeholder" when resultIsOutParamSupport = true, but it did not work well in practice. For example, it failed in the example above.
Instances For
Auxiliary structure for elaborating the application f args namedArgs.
- f : Expr
- fType : Expr
- Remaining regular arguments. 
- remaining named arguments to be processed. 
- When named arguments are provided and explicit arguments occurring before them are missing, the elaborator eta-expands the declaration. For example, - def f (x y : Nat) := x + y #check f (y := 5) -- fun x => f x 5- etaArgsstores the fresh free variables for implementing the eta-expansion. When- ..is used, eta-expansion is disabled, and missing arguments are treated as- _.
- Metavariables that we need to set the error context using the application being built. 
- Metavariables for the instance implicit arguments that have already been processed. 
- propagateExpected : BoolThe following field is used to implement the propagateExpectedTypeheuristic. It is set totruetrue whenexpectedTypestill has to be propagated.
- If the result type may be the - outParamof some local instance. See comment at- Context.resultIsOutParamSupport
- Valid named arguments found while traversing the function's type. 
Instances For
Equations
Instances For
Try to synthesize metavariables are instMVars using type class resolution.
The ones that cannot be synthesized yet stay in the instMVars list.
Remark: we use this method
- before trying to apply coercions to function,
- before unifying the expected type.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Try to synthesize metavariables are instMVars using type class resolution.
The ones that cannot be synthesized yet are registered.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Eliminator-like function application elaborator #
Information about an eliminator used by the elab-as-elim elaborator.
This is not to be confused with Lean.Meta.ElimInfo, which is for induction and cases.
The elab-as-elim routine is less restrictive in what counts as an eliminator, and it doesn't need
to have a strict notion of what is a "target" — all it cares about are
- that the return type of a function is of the form m ...wheremis a parameter (unlikeinductionandcaseseliminators, the arguments tom, known as "discriminants", can be any expressions, not just parameters), and
- which arguments should be eagerly elaborated, to make discriminants be as elaborated as possible for the expected type generalization procedure, and which should be postponed (since they are the "minor premises").
Note that the routine isn't doing induction/cases on particular expressions. The purpose of elab-as-elim is to successfully solve the higher-order unification problem between the return type of the function and the expected type.
- elimExpr : ExprThe eliminator. 
- elimType : ExprThe type of the eliminator. 
- motivePos : NatThe position of the motive parameter. 
- Positions of "major" parameters (those that should be eagerly elaborated because they can contribute to the motive inference procedure). All parameters that are neither the motive nor a major parameter are "minor" parameters. The major parameters include all of the parameters that transitively appear in the motive's arguments, as well as "first-order" arguments that include such parameters, since they too can help with elaborating discriminants. - For example, in the following theorem the argument - h : a = bshould be elaborated eagerly because it contains- b, which occurs in- motive b.- theorem Eq.subst' {α} {motive : α → Prop} {a b : α} (h : a = b) : motive a → motive b- For another example, the term - isEmptyElim (α := α)is an underapplied eliminator, and it needs argument- αto be elaborated eagerly to create a type-correct motive.- def isEmptyElim [IsEmpty α] {p : α → Sort _} (a : α) : p a := ... example {α : Type _} [IsEmpty α] : id (α → False) := isEmptyElim (α := α)
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Equations
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.Elab.Term.getElabElimInfo elimName = do let __do_lift ← Lean.Meta.mkConstWithFreshMVarLevels elimName Lean.Elab.Term.getElabElimExprInfo __do_lift
Instances For
Instructs the elaborator that applications of this function should be elaborated like an eliminator.
An eliminator is a function that returns an application of a "motive." A motive is a parameter p
whose type is of the form (x₁ : _) → … → (xₙ : _) → Sort _, i.e., a function that takes in some
number of arguments (referred to as "major premises") and returns a type. The arguments x₁
through xₙ of the motive can be arbitrary expressions. When elaborating an eliminator application,
Lean first solves for p by matching p x₁ … xₙ against the expected type, then replacing xₙ
through x₁ (in that order) with variables to obtain the body of p. The elaborator will throw an
error if this process fails (i.e., the resulting motive is not type-correct) or if the expected type
cannot be determined.
Eliminator elaboration can be compared to the induction tactic: The expected type is used as the
return value of the motive, with occurrences of the major premises replaced with the arguments.
When more arguments are specified than necessary, the remaining arguments are reverted into the
expected type.
The automatically-generated rec and casesOn functions of inductive types are always elaborated
as eliminators. Any other functions must be tagged with this attribute in order to be elaborated in
this fashion.
Examples:
@[elab_as_elim]
def evenOddRec {motive : Nat → Sort u}
    (even : ∀ n, motive (n * 2)) (odd : ∀ n, motive (n * 2 + 1))
    (n : Nat) : motive n := sorry
-- simple usage
example (a : Nat) : (a * a) % 2 = a % 2 :=
  evenOddRec _ _ a
  /-
  1. basic motive is `fun n => (a + 2) % 2 = a % 2`
  2. major premise `a` substituted: `fun n => (n + 2) % 2 = n % 2`
  3. now elaborate the other parameters as usual:
    "even" (first hole): expected type `∀ n, ((n * 2) * (n * 2)) % 2 = (n * 2) % 2`,
    "odd" (second hole): expected type `∀ n, ((n * 2 + 1) * (n * 2 + 1)) % 2 = (n * 2 + 1) % 2`
  -/
-- complex substitution
example (a : Nat) (f : Nat → Nat) : (f a + 1) % 2 ≠ f a :=
  evenOddRec _ _ (f a)
  /-
  Similar to before, except `f a` is substituted: `motive := fun n => (n + 1) % 2 ≠ n`.
  Now the first hole has expected type `∀ n, (n * 2 + 1) % 2 ≠ n * 2`.
  Now the second hole has expected type `∀ n, (n * 2 + 1 + 1) % 2 ≠ n * 2 + 1`.
  Note that while this might appear to work even if the `elab_as_elim` attribute is omitted from
  `evenOddRec`, the inferred motive if one does so (`fun n => (f a + 1) % 2 ≠ n`) is, in fact,
  insufficiently general: the first hole, for example, ends up with expected type
  `∀ (n : Nat), (f a + 1) % 2 ≠ n * 2`, leaving the first `f a` unsubstituted.
  -/
-- more parameters
example (a : Nat) (h : a % 2 = 1) : (a + 1) % 2 = 0 :=
  evenOddRec _ _ a h
  /-
  Before substitution, `a % 2 = 1` is reverted: `motive := fun n => a % 2 = 0 → (a + 1) % 2 = 0`.
  Substitution: `motive := fun n => n % 2 = 1 → (n + 1) % 2 = 0`
  Now the first hole has expected type `∀ n, n * 2 % 2 = 1 → (n * 2) % 2 = 0`.
  Now the second hole has expected type `∀ n, (n * 2 + 1) % 2 = 1 → (n * 2 + 1) % 2 = 0`.
  -/
See also @[induction_eliminator] and @[cases_eliminator] for registering default eliminators.
Context of the elab_as_elim elaboration procedure.
- elimInfo : ElabElimInfo
- expectedType : Expr
Instances For
State of the elab_as_elim elaboration procedure.
- f : ExprThe resultant expression being built. 
- fType : Expr`f : fType 
- User-provided named arguments that still have to be processed. 
- User-provided arguments that still have to be processed. 
- Instance implicit arguments collected so far. 
- idx : NatPosition of the next argument to be processed. We use it to decide whether the argument is the motive or a discriminant. 
- Store the metavariable used to represent the motive that will be computed at - finalize.
Instances For
Equations
Instances For
If the eliminator is over-applied, we "revert" the extra arguments. Returns the function with the reverted arguments applied and the new generalized expected type.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Construct the resulting application after all discriminants have been elaborated, and we have consumed as many given arguments as possible.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Return the next argument to be processed.
The result is .none if it is an implicit argument which was not provided using a named argument.
The result is .undef if args is empty and namedArgs does contain an entry for binderName.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Set the motive field in the state.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Save information for producing error messages.
Equations
- Lean.Elab.Term.ElabElim.saveArgInfo arg binderName = if arg.isMVar = true then liftM (Lean.Elab.Term.registerMVarArgName arg.mvarId! binderName) else pure PUnit.unit
Instances For
Create an implicit argument using the given BinderInfo.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Function application elaboration #
Elaborate a f-application using namedArgs and args as the arguments.
- expectedType?the expected type if available. It is used to propagate typing information only. This method does not ensure the result has this type.
- explicit = truewhen notation- @is used, and implicit arguments are assumed to be provided at- namedArgsand- args.
- ellipsis = truewhen notation- ..is used. That is, we add- _for missing arguments.
- resultIsOutParamSupportis used to control whether special support is used when processing applications of functions that return output parameter of some local instance. Example:
 The result type- GetElem.getElem : {Cont : Type u_1} → {Idx : Type u_2} → {elem : Type u_3} → {dom : cont → idx → Prop} → [self : GetElem cont idx elem dom] → (xs : cont) → (i : idx) → dom xs i → elem- elemis the output parameter of the local instance- self. When this parameter is set to- true, we execute- synthesizeSyntheticMVarsUsingDefault. For additional details, see comment at- ElabAppArgs.resultIsOutParam.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Auxiliary inductive datatype that represents the resolution of an LVal.
- projFn
(baseStructName structName fieldName : Name)
 : LValResolutionWhen applied to f, effectively expands toBaseStruct.fieldName (self := Struct.toBase f). This is a special named argument where it suppresses any explicit arguments depending on it so that type parameters don't need to be supplied.
- projIdx (structName : Name) (idx : Nat) : LValResolution
- const
(baseStructName structName constName : Name)
 : LValResolutionWhen applied to f, effectively expands toconstName ... (Struct.toBase f), with the argument placed in the correct positional argument if possible, or otherwise as a named argument. TheStruct.toBaseis not present ifbaseStructName == structName, in which case these do not need to be structures. Supports generalized field notation.
- localRec
(baseName : Name)
(fvar : Expr)
 : LValResolutionLike const, but withfvarinstead ofconstName. ThebaseNameis the base name of the type to search for in the parameter list.
Instances For
Interaction between errToSorry and observing. #
- The method - elabTermcatches exceptions, logs them, and returns a synthetic sorry (IF- ctx.errToSorry== true).
- When we elaborate choice nodes (and overloaded identifiers), we track multiple results using the - observing xcombinator. The- observing xexecutes- xand returns a- TermElabResult.
observing x does not check for synthetic sorry's, just an exception. Thus, it may think x worked when it didn't
if a synthetic sorry was introduced. We decided that checking for synthetic sorrys at observing is not a good solution
because it would not be clear to decide what the "main" error message for the alternative is. When the result contains
a synthetic sorry, it is not clear which error message corresponds to the sorry. Moreover, while executing x, many
error messages may have been logged. Recall that we need an error per alternative at mergeFailures.
Thus, we decided to set errToSorry to false whenever processing choice nodes and overloaded symbols.
Important: we rely on the property that after errToSorry is set to
false, no elaboration function executed by x will reset it to
true.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Instances For
Instances For
Instances For
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.