#print dependents
command #
This is a variation on #print axioms
where one instead specifies the axioms to avoid,
and it prints a list of all the theorems in the file that depend on that axiom, and the list
of all theorems directly referenced that are "to blame" for this dependency. Useful for debugging
unexpected dependencies.
Collects the result of a CollectDependents
query.
- otherAxiom : Bool
If true, an axiom not in the initial list will be considered as marked.
- result : Lean.NameMap Bool
The cached results on visited constants.
Instances For
The monad used by CollectDependents
.
Equations
Instances For
Constructs the initial state, marking the constants in cs
. The result of collect
will say
whether a given declaration depends transitively on one of these constants.
If otherAxiom
is true, any axiom not specified in cs
will also be tracked.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Collect the results for a given constant.
The command #print dependents X Y
prints a list of all the declarations in the file that
transitively depend on X
or Y
. After each declaration, it shows the list of all declarations
referred to directly in the body which also depend on X
or Y
.
For example, #print axioms bar'
below shows that bar'
depends on Classical.choice
, but not
why. #print dependents Classical.choice
says that bar'
depends on Classical.choice
because
it uses foo
and foo
uses Classical.em
. bar
is not listed because it is proved without using
Classical.choice
.
import Batteries.Tactic.PrintDependents
theorem foo : x = y ∨ x ≠ y := Classical.em _
theorem bar : 1 = 1 ∨ 1 ≠ 1 := by simp
theorem bar' : 1 = 1 ∨ 1 ≠ 1 := foo
#print axioms bar'
-- 'bar'' depends on axioms: [Classical.choice, Quot.sound, propext]
#print dependents Classical.choice
-- foo: Classical.em
-- bar': foo
Equations
- One or more equations did not get rendered due to their size.