lean4-htt/tests/lean/run/2161.lean
jrr6 62f14514da
refactor: update built-in tactic error messages (#9633)
This PR updates various error messages produced by or associated with
built-in tactics and adapts their formatting to current conventions.
2025-07-31 14:16:57 +00:00

48 lines
1.5 KiB
Text

structure Foo where num : Nat deriving DecidableEq
namespace Foo
instance : OfNat Foo n := ⟨⟨n⟩⟩
/-! # Example 1 -/
@[irreducible] def mul (a b : Foo) : Foo :=
let d := Nat.gcd a.num 1
⟨(a.num.div d) * (b.num.div d)⟩
-- should fail fast; exact heartbeat count at time of writing is 31
set_option maxHeartbeats 310
/--
error: Tactic `decide` failed for proposition
((mul 4 1).mul 1).mul 1 = 4
because its `Decidable` instance
instDecidableEqFoo (((mul 4 1).mul 1).mul 1) 4
did not reduce to `isTrue` or `isFalse`.
After unfolding the instances `decEqFoo✝`, `instDecidableEqFoo`, `instDecidableEqNat`, and `Nat.decEq`, reduction got stuck at the `Decidable` instance
match h : (((mul 4 1).mul 1).mul 1).num.beq 4 with
| true => isTrue ⋯
| false => isFalse ⋯
-/
#guard_msgs in
example : ((Foo.mul 4 1).mul 1).mul 1 = 4 := by decide
/-! # Example 2 -/
@[irreducible] def add (a b : Foo) : Foo := ⟨a.num * b.num⟩
-- should not succeed (and fail fast); exact heartbeat count at time of writing is 21
/--
error: Tactic `decide` failed for proposition
((add 4 1).add 1).add 1 = 4
because its `Decidable` instance
instDecidableEqFoo (((add 4 1).add 1).add 1) 4
did not reduce to `isTrue` or `isFalse`.
After unfolding the instances `decEqFoo✝`, `instDecidableEqFoo`, `instDecidableEqNat`, and `Nat.decEq`, reduction got stuck at the `Decidable` instance
match h : (((add 4 1).add 1).add 1).num.beq 4 with
| true => isTrue ⋯
| false => isFalse ⋯
-/
#guard_msgs in
example : ((Foo.add 4 1).add 1).add 1 = 4 := by decide