|
|
@ -39,15 +39,15 @@ protected def GoalState.create (expr: Expr): Elab.TermElabM GoalState := do
|
|
|
|
|
|
|
|
|
|
|
|
--Elab.Term.synthesizeSyntheticMVarsNoPostponing
|
|
|
|
--Elab.Term.synthesizeSyntheticMVarsNoPostponing
|
|
|
|
--let expr ← instantiateMVars expr
|
|
|
|
--let expr ← instantiateMVars expr
|
|
|
|
let root ← Meta.mkFreshExprMVar expr (kind := MetavarKind.synthetic) (userName := .anonymous)
|
|
|
|
let goal ← Meta.mkFreshExprMVar expr (kind := MetavarKind.synthetic) (userName := .anonymous)
|
|
|
|
let savedStateMonad: Elab.Tactic.TacticM Elab.Tactic.SavedState := MonadBacktrack.saveState
|
|
|
|
let savedStateMonad: Elab.Tactic.TacticM Elab.Tactic.SavedState := MonadBacktrack.saveState
|
|
|
|
let savedState ← savedStateMonad { elaborator := .anonymous } |>.run' { goals := [root.mvarId!]}
|
|
|
|
let root := goal.mvarId!
|
|
|
|
|
|
|
|
let savedState ← savedStateMonad { elaborator := .anonymous } |>.run' { goals := [root]}
|
|
|
|
return {
|
|
|
|
return {
|
|
|
|
root := root.mvarId!,
|
|
|
|
root,
|
|
|
|
savedState,
|
|
|
|
savedState,
|
|
|
|
parentMVar? := .none,
|
|
|
|
parentMVar? := .none,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@[export pantograph_goal_state_is_conv]
|
|
|
|
|
|
|
|
protected def GoalState.isConv (state: GoalState): Bool :=
|
|
|
|
protected def GoalState.isConv (state: GoalState): Bool :=
|
|
|
|
state.convMVar?.isSome
|
|
|
|
state.convMVar?.isSome
|
|
|
|
protected def GoalState.goals (state: GoalState): List MVarId :=
|
|
|
|
protected def GoalState.goals (state: GoalState): List MVarId :=
|
|
|
@ -63,16 +63,17 @@ protected def GoalState.env (state: GoalState): Environment :=
|
|
|
|
protected def GoalState.metaContextOfGoal (state: GoalState) (mvarId: MVarId): Option Meta.Context := do
|
|
|
|
protected def GoalState.metaContextOfGoal (state: GoalState) (mvarId: MVarId): Option Meta.Context := do
|
|
|
|
let mvarDecl ← state.mctx.findDecl? mvarId
|
|
|
|
let mvarDecl ← state.mctx.findDecl? mvarId
|
|
|
|
return { lctx := mvarDecl.lctx, localInstances := mvarDecl.localInstances }
|
|
|
|
return { lctx := mvarDecl.lctx, localInstances := mvarDecl.localInstances }
|
|
|
|
|
|
|
|
@[export pantograph_goal_state_meta_state]
|
|
|
|
protected def GoalState.metaState (state: GoalState): Meta.State :=
|
|
|
|
protected def GoalState.metaState (state: GoalState): Meta.State :=
|
|
|
|
state.savedState.term.meta.meta
|
|
|
|
state.savedState.term.meta.meta
|
|
|
|
|
|
|
|
|
|
|
|
protected def GoalState.withContext (state: GoalState) (mvarId: MVarId) (m: MetaM α): MetaM α := do
|
|
|
|
protected def GoalState.withContext (state: GoalState) (mvarId: MVarId) (m: MetaM α): MetaM α := do
|
|
|
|
mvarId.withContext m |>.run' (← read) state.metaState
|
|
|
|
mvarId.withContext m |>.run' (← read) state.metaState
|
|
|
|
|
|
|
|
|
|
|
|
protected def GoalState.withParentContext { n } [MonadControlT MetaM n] [Monad n] (state: GoalState): n α → n α :=
|
|
|
|
protected def GoalState.withParentContext (state: GoalState) (m: MetaM α): MetaM α := do
|
|
|
|
Meta.mapMetaM <| state.withContext state.parentMVar?.get!
|
|
|
|
state.withContext state.parentMVar?.get! m
|
|
|
|
protected def GoalState.withRootContext { n } [MonadControlT MetaM n] [Monad n] (state: GoalState): n α → n α :=
|
|
|
|
protected def GoalState.withRootContext (state: GoalState) (m: MetaM α): MetaM α := do
|
|
|
|
Meta.mapMetaM <| state.withContext state.root
|
|
|
|
state.withContext state.root m
|
|
|
|
|
|
|
|
|
|
|
|
private def GoalState.mvars (state: GoalState): SSet MVarId :=
|
|
|
|
private def GoalState.mvars (state: GoalState): SSet MVarId :=
|
|
|
|
state.mctx.decls.foldl (init := .empty) fun acc k _ => acc.insert k
|
|
|
|
state.mctx.decls.foldl (init := .empty) fun acc k _ => acc.insert k
|
|
|
@ -84,7 +85,7 @@ private def GoalState.restoreTacticM (state: GoalState) (goal: MVarId): Elab.Tac
|
|
|
|
state.savedState.restore
|
|
|
|
state.savedState.restore
|
|
|
|
Elab.Tactic.setGoals [goal]
|
|
|
|
Elab.Tactic.setGoals [goal]
|
|
|
|
|
|
|
|
|
|
|
|
@[export pantograph_goal_state_focus]
|
|
|
|
|
|
|
|
protected def GoalState.focus (state: GoalState) (goalId: Nat): Option GoalState := do
|
|
|
|
protected def GoalState.focus (state: GoalState) (goalId: Nat): Option GoalState := do
|
|
|
|
let goal ← state.savedState.tactic.goals.get? goalId
|
|
|
|
let goal ← state.savedState.tactic.goals.get? goalId
|
|
|
|
return {
|
|
|
|
return {
|
|
|
@ -120,7 +121,6 @@ protected def GoalState.resume (state: GoalState) (goals: List MVarId): Except S
|
|
|
|
/--
|
|
|
|
/--
|
|
|
|
Brings into scope all goals from `branch`
|
|
|
|
Brings into scope all goals from `branch`
|
|
|
|
-/
|
|
|
|
-/
|
|
|
|
@[export pantograph_goal_state_continue]
|
|
|
|
|
|
|
|
protected def GoalState.continue (target: GoalState) (branch: GoalState): Except String GoalState :=
|
|
|
|
protected def GoalState.continue (target: GoalState) (branch: GoalState): Except String GoalState :=
|
|
|
|
if !target.goals.isEmpty then
|
|
|
|
if !target.goals.isEmpty then
|
|
|
|
.error s!"Target state has unresolved goals"
|
|
|
|
.error s!"Target state has unresolved goals"
|
|
|
@ -233,7 +233,6 @@ protected def GoalState.tryLet (state: GoalState) (goalId: Nat) (binderName: Str
|
|
|
|
state.tryTacticM goalId $ Tactic.evalLet binderName.toName type
|
|
|
|
state.tryTacticM goalId $ Tactic.evalLet binderName.toName type
|
|
|
|
|
|
|
|
|
|
|
|
/-- Enter conv tactic mode -/
|
|
|
|
/-- Enter conv tactic mode -/
|
|
|
|
@[export pantograph_goal_state_conv_m]
|
|
|
|
|
|
|
|
protected def GoalState.conv (state: GoalState) (goalId: Nat):
|
|
|
|
protected def GoalState.conv (state: GoalState) (goalId: Nat):
|
|
|
|
Elab.TermElabM TacticResult := do
|
|
|
|
Elab.TermElabM TacticResult := do
|
|
|
|
if state.convMVar?.isSome then
|
|
|
|
if state.convMVar?.isSome then
|
|
|
@ -264,7 +263,6 @@ protected def GoalState.conv (state: GoalState) (goalId: Nat):
|
|
|
|
return .failure #[← exception.toMessageData.toString]
|
|
|
|
return .failure #[← exception.toMessageData.toString]
|
|
|
|
|
|
|
|
|
|
|
|
/-- Exit from `conv` mode. Resumes all goals before the mode starts and applys the conv -/
|
|
|
|
/-- Exit from `conv` mode. Resumes all goals before the mode starts and applys the conv -/
|
|
|
|
@[export pantograph_goal_state_conv_exit_m]
|
|
|
|
|
|
|
|
protected def GoalState.convExit (state: GoalState):
|
|
|
|
protected def GoalState.convExit (state: GoalState):
|
|
|
|
Elab.TermElabM TacticResult := do
|
|
|
|
Elab.TermElabM TacticResult := do
|
|
|
|
let (convRhs, convGoal) ← match state.convMVar? with
|
|
|
|
let (convRhs, convGoal) ← match state.convMVar? with
|
|
|
@ -305,8 +303,6 @@ protected def GoalState.calcPrevRhsOf? (state: GoalState) (goalId: Nat) :=
|
|
|
|
state.calcPrevRhs?
|
|
|
|
state.calcPrevRhs?
|
|
|
|
else
|
|
|
|
else
|
|
|
|
.none
|
|
|
|
.none
|
|
|
|
|
|
|
|
|
|
|
|
@[export pantograph_goal_state_try_calc_m]
|
|
|
|
|
|
|
|
protected def GoalState.tryCalc (state: GoalState) (goalId: Nat) (pred: String):
|
|
|
|
protected def GoalState.tryCalc (state: GoalState) (goalId: Nat) (pred: String):
|
|
|
|
Elab.TermElabM TacticResult := do
|
|
|
|
Elab.TermElabM TacticResult := do
|
|
|
|
state.restoreElabM
|
|
|
|
state.restoreElabM
|
|
|
|