Skip to content

Commit

Permalink
chore: restoring Option simp confluence
Browse files Browse the repository at this point in the history
  • Loading branch information
kim-em committed Sep 11, 2024
1 parent 325a058 commit 5f8e176
Showing 1 changed file with 33 additions and 1 deletion.
34 changes: 33 additions & 1 deletion src/Init/Data/Option/Lemmas.lean
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ namespace Option

theorem mem_iff {a : α} {b : Option α} : a ∈ b ↔ b = some a := .rfl

@[simp] theorem mem_some {a b : α} : a ∈ some b ↔ a = b := by simp [mem_iff, eq_comm]
@[simp] theorem mem_some {a b : α} : a ∈ some b ↔ b = a := by simp [mem_iff]

theorem mem_some_self (a : α) : a ∈ some a := mem_some.2 rfl

Expand Down Expand Up @@ -432,6 +432,38 @@ section ite
(x ∈ if p then l else none) ↔ p ∧ x ∈ l := by
split <;> simp_all

@[simp] theorem dite_none_left_eq_some {p : Prop} [Decidable p] {b : ¬p → Option β} :
(if h : p then none else b h) = some a ↔ ∃ h, b h = some a := by
split <;> simp_all

@[simp] theorem dite_none_right_eq_some {p : Prop} [Decidable p] {b : p → Option α} :
(if h : p then b h else none) = some a ↔ ∃ h, b h = some a := by
split <;> simp_all

@[simp] theorem some_eq_dite_none_left {p : Prop} [Decidable p] {b : ¬p → Option β} :
some a = (if h : p then none else b h) ↔ ∃ h, some a = b h := by
split <;> simp_all

@[simp] theorem some_eq_dite_none_right {p : Prop} [Decidable p] {b : p → Option α} :
some a = (if h : p then b h else none) ↔ ∃ h, some a = b h := by
split <;> simp_all

@[simp] theorem ite_none_left_eq_some {p : Prop} [Decidable p] {b : Option β} :
(if p then none else b) = some a ↔ ¬ p ∧ b = some a := by
split <;> simp_all

@[simp] theorem ite_none_right_eq_some {p : Prop} [Decidable p] {b : Option α} :
(if p then b else none) = some a ↔ p ∧ b = some a := by
split <;> simp_all

@[simp] theorem some_eq_ite_none_left {p : Prop} [Decidable p] {b : Option β} :
some a = (if p then none else b) ↔ ¬ p ∧ some a = b := by
split <;> simp_all

@[simp] theorem some_eq_ite_none_right {p : Prop} [Decidable p] {b : Option α} :
some a = (if p then b else none) ↔ p ∧ some a = b := by
split <;> simp_all

@[simp] theorem isSome_dite {p : Prop} [Decidable p] {b : p → β} :
(if h : p then some (b h) else none).isSome = true ↔ p := by
split <;> simpa
Expand Down

0 comments on commit 5f8e176

Please sign in to comment.