summaryrefslogtreecommitdiff
path: root/backends/lean/Base/Diverge
diff options
context:
space:
mode:
authorSon Ho2023-07-09 10:11:13 +0200
committerSon Ho2023-07-09 10:11:13 +0200
commit0d1ac53f88f947ae94f6afb57b2a7e18a77460a7 (patch)
tree07870dd80b1d04d25c3f304f5bb7b4421ecc90ac /backends/lean/Base/Diverge
parent9515bbad5b58ed1c51ac6d9fc9d7a4e5884b6273 (diff)
Make progress on the int tactic
Diffstat (limited to 'backends/lean/Base/Diverge')
-rw-r--r--backends/lean/Base/Diverge/ElabBase.lean112
1 files changed, 0 insertions, 112 deletions
diff --git a/backends/lean/Base/Diverge/ElabBase.lean b/backends/lean/Base/Diverge/ElabBase.lean
index aaaea6f7..fedb1c74 100644
--- a/backends/lean/Base/Diverge/ElabBase.lean
+++ b/backends/lean/Base/Diverge/ElabBase.lean
@@ -12,116 +12,4 @@ initialize registerTraceClass `Diverge.def.genBody
initialize registerTraceClass `Diverge.def.valid
initialize registerTraceClass `Diverge.def.unfold
--- Useful helper to explore definitions and figure out the variant
--- of their sub-expressions.
-def explore_term (incr : String) (e : Expr) : MetaM Unit :=
- match e with
- | .bvar _ => do logInfo m!"{incr}bvar: {e}"; return ()
- | .fvar _ => do logInfo m!"{incr}fvar: {e}"; return ()
- | .mvar _ => do logInfo m!"{incr}mvar: {e}"; return ()
- | .sort _ => do logInfo m!"{incr}sort: {e}"; return ()
- | .const _ _ => do logInfo m!"{incr}const: {e}"; return ()
- | .app fn arg => do
- logInfo m!"{incr}app: {e}"
- explore_term (incr ++ " ") fn
- explore_term (incr ++ " ") arg
- | .lam _bName bTy body _binfo => do
- logInfo m!"{incr}lam: {e}"
- explore_term (incr ++ " ") bTy
- explore_term (incr ++ " ") body
- | .forallE _bName bTy body _bInfo => do
- logInfo m!"{incr}forallE: {e}"
- explore_term (incr ++ " ") bTy
- explore_term (incr ++ " ") body
- | .letE _dName ty val body _nonDep => do
- logInfo m!"{incr}letE: {e}"
- explore_term (incr ++ " ") ty
- explore_term (incr ++ " ") val
- explore_term (incr ++ " ") body
- | .lit _ => do logInfo m!"{incr}lit: {e}"; return ()
- | .mdata _ e => do
- logInfo m!"{incr}mdata: {e}"
- explore_term (incr ++ " ") e
- | .proj _ _ struct => do
- logInfo m!"{incr}proj: {e}"
- explore_term (incr ++ " ") struct
-
-def explore_decl (n : Name) : TermElabM Unit := do
- logInfo m!"Name: {n}"
- let env ← getEnv
- let decl := env.constants.find! n
- match decl with
- | .defnInfo val =>
- logInfo m!"About to explore defn: {decl.name}"
- logInfo m!"# Type:"
- explore_term "" val.type
- logInfo m!"# Value:"
- explore_term "" val.value
- | .axiomInfo _ => throwError m!"axiom: {n}"
- | .thmInfo _ => throwError m!"thm: {n}"
- | .opaqueInfo _ => throwError m!"opaque: {n}"
- | .quotInfo _ => throwError m!"quot: {n}"
- | .inductInfo _ => throwError m!"induct: {n}"
- | .ctorInfo _ => throwError m!"ctor: {n}"
- | .recInfo _ => throwError m!"rec: {n}"
-
-syntax (name := printDecl) "print_decl " ident : command
-
-open Lean.Elab.Command
-
-@[command_elab printDecl] def elabPrintDecl : CommandElab := fun stx => do
- liftTermElabM do
- let id := stx[1]
- addCompletionInfo <| CompletionInfo.id id id.getId (danglingDot := false) {} none
- let cs ← resolveGlobalConstWithInfos id
- explore_decl cs[0]!
-
-private def test1 : Nat := 0
-private def test2 (x : Nat) : Nat := x
-
-print_decl test1
-print_decl test2
-
--- A map visitor function for expressions (adapted from `AbstractNestedProofs.visit`)
--- The continuation takes as parameters:
--- - the current depth of the expression (useful for printing/debugging)
--- - the expression to explore
-partial def mapVisit (k : Nat → Expr → MetaM Expr) (e : Expr) : MetaM Expr := do
- let mapVisitBinders (xs : Array Expr) (k2 : MetaM Expr) : MetaM Expr := do
- let localInstances ← getLocalInstances
- let mut lctx ← getLCtx
- for x in xs do
- let xFVarId := x.fvarId!
- let localDecl ← xFVarId.getDecl
- let type ← mapVisit k localDecl.type
- let localDecl := localDecl.setType type
- let localDecl ← match localDecl.value? with
- | some value => let value ← mapVisit k value; pure <| localDecl.setValue value
- | none => pure localDecl
- lctx :=lctx.modifyLocalDecl xFVarId fun _ => localDecl
- withLCtx lctx localInstances k2
- -- TODO: use a cache? (Lean.checkCache)
- let rec visit (i : Nat) (e : Expr) : MetaM Expr := do
- -- Explore
- let e ← k i e
- match e with
- | .bvar _
- | .fvar _
- | .mvar _
- | .sort _
- | .lit _
- | .const _ _ => pure e
- | .app .. => do e.withApp fun f args => return mkAppN f (← args.mapM (visit (i + 1)))
- | .lam .. =>
- lambdaLetTelescope e fun xs b =>
- mapVisitBinders xs do mkLambdaFVars xs (← visit (i + 1) b) (usedLetOnly := false)
- | .forallE .. => do
- forallTelescope e fun xs b => mapVisitBinders xs do mkForallFVars xs (← visit (i + 1) b)
- | .letE .. => do
- lambdaLetTelescope e fun xs b => mapVisitBinders xs do
- mkLambdaFVars xs (← visit (i + 1) b) (usedLetOnly := false)
- | .mdata _ b => return e.updateMData! (← visit (i + 1) b)
- | .proj _ _ b => return e.updateProj! (← visit (i + 1) b)
- visit 0 e
-
end Diverge