Similar to Lean.Core.mkFreshUserName
, but takes into account the tactic.hygienic
option value.
If tactic.hygienic = true
, then fresh macro scopes are applied to binderName
.
If not, then returns an (accessible) name based on binderName
that is unused in the local context.
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`.
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.