lean4-htt/tests/lean/run/4413.lean
Kyle Miller 28cf146d00
fix: make sure monad lift coercion elaborator has no side effects (#6024)
This PR fixes a bug where the monad lift coercion elaborator would
partially unify expressions even if they were not monads. This could be
taken advantage of to propagate information that could help elaboration
make progress, for example the first `change` worked because the monad
lift coercion elaborator was unifying `@Eq _ _` with `@Eq (Nat × Nat)
p`:
```lean
example (p : Nat × Nat) : p = p := by
  change _ = ⟨_, _⟩ -- used to work (yielding `p = (p.fst, p.snd)`), now it doesn't
  change ⟨_, _⟩ = _ -- never worked
```
As such, this is a breaking change; you may need to adjust expressions
to include additional implicit arguments.
2024-11-13 16:22:31 +00:00

51 lines
1.1 KiB
Text

set_option pp.mvars false
structure Note where
pitch : UInt64
start : Nat
def Note.containsNote (n1 n2 : Note) : Prop :=
n1.start ≤ n2.start
def Note.lowerSemitone (n : Note) : Note :=
{ n with pitch := n.pitch - 1 }
theorem Note.self_containsNote_lowerSemitone_self (n : Note) :
n.containsNote (Note.lowerSemitone n) := by
simp [Note.containsNote, Note.lowerSemitone]
/--
error: type mismatch
rfl
has type
?_ = ?_ : Prop
but is expected to have type
n = n - 1 : Prop
-/
#guard_msgs in
set_option maxRecDepth 100 in
set_option maxHeartbeats 200 in
example (n : UInt64) : n = n - 1 :=
rfl
namespace Ex2
def lowerSemitone := fun (n : Note) => Note.mk (n.1 - 0) n.2
set_option maxRecDepth 100 in
theorem Note.self_containsNote_lowerSemitone_self (n : Note) :
0 ≤ (lowerSemitone n).start :=
(Nat.zero_le (Note.start n))
end Ex2
namespace Ex3
def lowerSemitone := fun (n : Note) => Note.mk (n.1 + 100) n.2
set_option maxRecDepth 200 in
theorem Note.self_containsNote_lowerSemitone_self (n : Note) :
0 ≤ (lowerSemitone n).start :=
(Nat.zero_le (Note.start n))
end Ex3