Similar to mkFreshUserName
, but takes into account tactic.hygienic
option value.
If tactic.hygienic = true
, then the current macro scopes are applied to binderName
.
If not, then an unused (accessible) name (based on binderName
) in the local context is used.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Introduce n
binders in the goal mvarId
.
Equations
- mvarId.introN n givenNames useNamesForExplicitOnly = Lean.Meta.introNCore mvarId n givenNames useNamesForExplicitOnly false
Instances For
Introduce n
binders in the goal mvarId
. The new hypotheses are named using the binder names.
The suffix P
stands for "preserving`.
Equations
- mvarId.introNP n = Lean.Meta.introNCore mvarId n [] false true
Instances For
Introduce one object from the goal mvarid
, without preserving the name used in the binder.
Returns a pair made of the newly introduced variable (which will have an inaccessible name)
and the new goal. This will fail if there is nothing to introduce, ie when the goal
does not start with a forall, lambda or let.
Equations
- mvarId.intro1 = Lean.Meta.intro1Core mvarId false
Instances For
Introduce one object from the goal mvarid
, preserving the name used in the binder.
Returns a pair made of the newly introduced variable and the new goal.
This will fail if there is nothing to introduce, ie when the goal
does not start with a forall, lambda or let.
Equations
- mvarId.intro1P = Lean.Meta.intro1Core mvarId true
Instances For
Calculate the number of new hypotheses that would be created by intros
,
i.e. the number of binders which can be introduced without unfolding definitions.
Introduce as many binders as possible without unfolding definitions.
Equations
- mvarId.intros = do let type ← mvarId.getType let type ← Lean.instantiateMVars type let n : Nat := Lean.Meta.getIntrosSize type if (n == 0) = true then pure (#[], mvarId) else mvarId.introN n